From e2deffe54d7285bcf0978e5170191aae440db60b Mon Sep 17 00:00:00 2001 From: rk18venom Date: Thu, 28 Oct 2021 14:23:58 -0700 Subject: [PATCH] Task4 --- Rahul/task4/Crawler/crawler.py | 113 + Rahul/task4/Crawler/popularlinks.py | 18 + Rahul/task4/Templates/base.html | 37 + Rahul/task4/Templates/home.html | 22 + Rahul/task4/Templates/search_result.html | 40 + .../query_processing.cpython-39.pyc | Bin 0 -> 1496 bytes .../task4/__pycache__/ranking.cpython-39.pyc | Bin 0 -> 1682 bytes Rahul/task4/app.py | 75 + .../Flask-2.0.2.dist-info/INSTALLER | 1 + .../Flask-2.0.2.dist-info/LICENSE.rst | 28 + .../Flask-2.0.2.dist-info/METADATA | 125 + .../Flask-2.0.2.dist-info/RECORD | 52 + .../Flask-2.0.2.dist-info/REQUESTED | 0 .../site-packages/Flask-2.0.2.dist-info/WHEEL | 5 + .../Flask-2.0.2.dist-info/entry_points.txt | 3 + .../Flask-2.0.2.dist-info/top_level.txt | 1 + .../Jinja2-3.0.2.dist-info/INSTALLER | 1 + .../Jinja2-3.0.2.dist-info/LICENSE.rst | 28 + .../Jinja2-3.0.2.dist-info/METADATA | 113 + .../Jinja2-3.0.2.dist-info/RECORD | 58 + .../Jinja2-3.0.2.dist-info/WHEEL | 5 + .../Jinja2-3.0.2.dist-info/entry_points.txt | 3 + .../Jinja2-3.0.2.dist-info/top_level.txt | 1 + .../MarkupSafe-2.0.1.dist-info/INSTALLER | 1 + .../MarkupSafe-2.0.1.dist-info/LICENSE.rst | 28 + .../MarkupSafe-2.0.1.dist-info/METADATA | 100 + .../MarkupSafe-2.0.1.dist-info/RECORD | 13 + .../MarkupSafe-2.0.1.dist-info/WHEEL | 5 + .../MarkupSafe-2.0.1.dist-info/top_level.txt | 1 + .../Werkzeug-2.0.2.dist-info/INSTALLER | 1 + .../Werkzeug-2.0.2.dist-info/LICENSE.rst | 28 + .../Werkzeug-2.0.2.dist-info/METADATA | 129 + .../Werkzeug-2.0.2.dist-info/RECORD | 111 + .../Werkzeug-2.0.2.dist-info/WHEEL | 5 + .../Werkzeug-2.0.2.dist-info/top_level.txt | 1 + .../__pycache__/ranking.cpython-38.pyc | Bin 0 -> 5142 bytes .../__pycache__/ranking.cpython-39.pyc | Bin 0 -> 5151 bytes .../site-packages/_distutils_hack/__init__.py | 128 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 5075 bytes .../__pycache__/override.cpython-39.pyc | Bin 0 -> 207 bytes .../site-packages/_distutils_hack/override.py | 1 + .../beautifulsoup4-4.10.0.dist-info/AUTHORS | 49 + .../COPYING.txt | 27 + .../beautifulsoup4-4.10.0.dist-info/INSTALLER | 1 + .../beautifulsoup4-4.10.0.dist-info/LICENSE | 30 + .../beautifulsoup4-4.10.0.dist-info/METADATA | 120 + .../beautifulsoup4-4.10.0.dist-info/RECORD | 29 + .../beautifulsoup4-4.10.0.dist-info/REQUESTED | 0 .../beautifulsoup4-4.10.0.dist-info/WHEEL | 5 + .../top_level.txt | 1 + .../Lib/site-packages/bs4/__init__.py | 804 ++ .../bs4/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 23158 bytes .../bs4/__pycache__/dammit.cpython-39.pyc | Bin 0 -> 71344 bytes .../bs4/__pycache__/diagnose.cpython-39.pyc | Bin 0 -> 8435 bytes .../bs4/__pycache__/element.cpython-39.pyc | Bin 0 -> 65406 bytes .../bs4/__pycache__/formatter.cpython-39.pyc | Bin 0 -> 6148 bytes .../bs4/__pycache__/testing.cpython-39.pyc | Bin 0 -> 44313 bytes .../Lib/site-packages/bs4/builder/__init__.py | 520 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 15380 bytes .../__pycache__/_html5lib.cpython-39.pyc | Bin 0 -> 12470 bytes .../__pycache__/_htmlparser.cpython-39.pyc | Bin 0 -> 13043 bytes .../builder/__pycache__/_lxml.cpython-39.pyc | Bin 0 -> 9475 bytes .../site-packages/bs4/builder/_html5lib.py | 467 + .../site-packages/bs4/builder/_htmlparser.py | 492 + .../Lib/site-packages/bs4/builder/_lxml.py | 342 + .../pyvenv3.9/Lib/site-packages/bs4/dammit.py | 3338 +++++++ .../Lib/site-packages/bs4/diagnose.py | 242 + .../Lib/site-packages/bs4/element.py | 2255 +++++ .../Lib/site-packages/bs4/formatter.py | 165 + .../Lib/site-packages/bs4/testing.py | 1136 +++ .../Lib/site-packages/bson/__init__.py | 1274 +++ .../bson/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 36366 bytes .../bson/__pycache__/binary.cpython-39.pyc | Bin 0 -> 9989 bytes .../bson/__pycache__/code.cpython-39.pyc | Bin 0 -> 2891 bytes .../__pycache__/codec_options.cpython-39.pyc | Bin 0 -> 12394 bytes .../bson/__pycache__/dbref.cpython-39.pyc | Bin 0 -> 4479 bytes .../__pycache__/decimal128.cpython-39.pyc | Bin 0 -> 9722 bytes .../bson/__pycache__/errors.cpython-39.pyc | Bin 0 -> 1224 bytes .../bson/__pycache__/int64.cpython-39.pyc | Bin 0 -> 776 bytes .../bson/__pycache__/json_util.cpython-39.pyc | Bin 0 -> 23783 bytes .../bson/__pycache__/max_key.cpython-39.pyc | Bin 0 -> 1517 bytes .../bson/__pycache__/min_key.cpython-39.pyc | Bin 0 -> 1517 bytes .../bson/__pycache__/objectid.cpython-39.pyc | Bin 0 -> 9030 bytes .../bson/__pycache__/py3compat.cpython-39.pyc | Bin 0 -> 2620 bytes .../bson/__pycache__/raw_bson.cpython-39.pyc | Bin 0 -> 5985 bytes .../bson/__pycache__/regex.cpython-39.pyc | Bin 0 -> 4063 bytes .../bson/__pycache__/son.cpython-39.pyc | Bin 0 -> 6393 bytes .../bson/__pycache__/timestamp.cpython-39.pyc | Bin 0 -> 3874 bytes .../bson/__pycache__/tz_util.cpython-39.pyc | Bin 0 -> 1487 bytes .../bson/_cbson.cp39-win_amd64.pyd | Bin 0 -> 49152 bytes .../Lib/site-packages/bson/binary.py | 430 + .../pyvenv3.9/Lib/site-packages/bson/code.py | 99 + .../Lib/site-packages/bson/codec_options.py | 346 + .../pyvenv3.9/Lib/site-packages/bson/dbref.py | 135 + .../Lib/site-packages/bson/decimal128.py | 335 + .../Lib/site-packages/bson/errors.py | 40 + .../pyvenv3.9/Lib/site-packages/bson/int64.py | 34 + .../Lib/site-packages/bson/json_util.py | 863 ++ .../Lib/site-packages/bson/max_key.py | 50 + .../Lib/site-packages/bson/min_key.py | 50 + .../Lib/site-packages/bson/objectid.py | 299 + .../Lib/site-packages/bson/py3compat.py | 107 + .../Lib/site-packages/bson/raw_bson.py | 176 + .../pyvenv3.9/Lib/site-packages/bson/regex.py | 128 + .../pyvenv3.9/Lib/site-packages/bson/son.py | 200 + .../Lib/site-packages/bson/timestamp.py | 120 + .../Lib/site-packages/bson/tz_util.py | 52 + .../certifi-2021.10.8.dist-info/INSTALLER | 1 + .../certifi-2021.10.8.dist-info/LICENSE | 21 + .../certifi-2021.10.8.dist-info/METADATA | 83 + .../certifi-2021.10.8.dist-info/RECORD | 13 + .../certifi-2021.10.8.dist-info/WHEEL | 6 + .../certifi-2021.10.8.dist-info/top_level.txt | 1 + .../Lib/site-packages/certifi/__init__.py | 3 + .../Lib/site-packages/certifi/__main__.py | 12 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 232 bytes .../__pycache__/__main__.cpython-39.pyc | Bin 0 -> 397 bytes .../certifi/__pycache__/core.cpython-39.pyc | Bin 0 -> 1123 bytes .../Lib/site-packages/certifi/cacert.pem | 4362 +++++++++ .../Lib/site-packages/certifi/core.py | 60 + .../INSTALLER | 1 + .../LICENSE | 21 + .../METADATA | 267 + .../charset_normalizer-2.0.7.dist-info/RECORD | 33 + .../charset_normalizer-2.0.7.dist-info/WHEEL | 5 + .../entry_points.txt | 3 + .../top_level.txt | 1 + .../charset_normalizer/__init__.py | 47 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1539 bytes .../__pycache__/api.cpython-39.pyc | Bin 0 -> 9867 bytes .../__pycache__/cd.cpython-39.pyc | Bin 0 -> 8218 bytes .../__pycache__/constant.cpython-39.pyc | Bin 0 -> 13683 bytes .../__pycache__/legacy.cpython-39.pyc | Bin 0 -> 3009 bytes .../__pycache__/md.cpython-39.pyc | Bin 0 -> 14395 bytes .../__pycache__/models.cpython-39.pyc | Bin 0 -> 13157 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 7398 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 243 bytes .../site-packages/charset_normalizer/api.py | 528 + .../charset_normalizer/assets/__init__.py | 1244 +++ .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 7328 bytes .../site-packages/charset_normalizer/cd.py | 341 + .../charset_normalizer/cli/__init__.py | 0 .../cli/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 163 bytes .../cli/__pycache__/normalizer.cpython-39.pyc | Bin 0 -> 6111 bytes .../charset_normalizer/cli/normalizer.py | 291 + .../charset_normalizer/constant.py | 496 + .../charset_normalizer/legacy.py | 95 + .../site-packages/charset_normalizer/md.py | 540 ++ .../charset_normalizer/models.py | 393 + .../site-packages/charset_normalizer/py.typed | 0 .../site-packages/charset_normalizer/utils.py | 333 + .../charset_normalizer/version.py | 6 + .../click-8.0.3.dist-info/INSTALLER | 1 + .../click-8.0.3.dist-info/LICENSE.rst | 28 + .../click-8.0.3.dist-info/METADATA | 111 + .../click-8.0.3.dist-info/RECORD | 41 + .../site-packages/click-8.0.3.dist-info/WHEEL | 5 + .../click-8.0.3.dist-info/top_level.txt | 1 + .../Lib/site-packages/click/__init__.py | 75 + .../click/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2664 bytes .../click/__pycache__/_compat.cpython-39.pyc | Bin 0 -> 16013 bytes .../__pycache__/_termui_impl.cpython-39.pyc | Bin 0 -> 15976 bytes .../__pycache__/_textwrap.cpython-39.pyc | Bin 0 -> 1506 bytes .../__pycache__/_unicodefun.cpython-39.pyc | Bin 0 -> 2301 bytes .../__pycache__/_winconsole.cpython-39.pyc | Bin 0 -> 7757 bytes .../click/__pycache__/core.cpython-39.pyc | Bin 0 -> 88485 bytes .../__pycache__/decorators.cpython-39.pyc | Bin 0 -> 14267 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 10105 bytes .../__pycache__/formatting.cpython-39.pyc | Bin 0 -> 9385 bytes .../click/__pycache__/globals.cpython-39.pyc | Bin 0 -> 2407 bytes .../click/__pycache__/parser.cpython-39.pyc | Bin 0 -> 13540 bytes .../shell_completion.cpython-39.pyc | Bin 0 -> 16659 bytes .../click/__pycache__/termui.cpython-39.pyc | Bin 0 -> 26541 bytes .../click/__pycache__/testing.cpython-39.pyc | Bin 0 -> 15089 bytes .../click/__pycache__/types.cpython-39.pyc | Bin 0 -> 32871 bytes .../click/__pycache__/utils.cpython-39.pyc | Bin 0 -> 17745 bytes .../Lib/site-packages/click/_compat.py | 627 ++ .../Lib/site-packages/click/_termui_impl.py | 718 ++ .../Lib/site-packages/click/_textwrap.py | 49 + .../Lib/site-packages/click/_unicodefun.py | 100 + .../Lib/site-packages/click/_winconsole.py | 279 + .../pyvenv3.9/Lib/site-packages/click/core.py | 2953 ++++++ .../Lib/site-packages/click/decorators.py | 436 + .../Lib/site-packages/click/exceptions.py | 287 + .../Lib/site-packages/click/formatting.py | 301 + .../Lib/site-packages/click/globals.py | 69 + .../Lib/site-packages/click/parser.py | 529 + .../Lib/site-packages/click/py.typed | 0 .../site-packages/click/shell_completion.py | 581 ++ .../Lib/site-packages/click/termui.py | 809 ++ .../Lib/site-packages/click/testing.py | 479 + .../Lib/site-packages/click/types.py | 1052 ++ .../Lib/site-packages/click/utils.py | 579 ++ .../colorama-0.4.4.dist-info/INSTALLER | 1 + .../colorama-0.4.4.dist-info/LICENSE.txt | 27 + .../colorama-0.4.4.dist-info/METADATA | 415 + .../colorama-0.4.4.dist-info/RECORD | 18 + .../colorama-0.4.4.dist-info/WHEEL | 6 + .../colorama-0.4.4.dist-info/top_level.txt | 1 + .../Lib/site-packages/colorama/__init__.py | 6 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 400 bytes .../colorama/__pycache__/ansi.cpython-39.pyc | Bin 0 -> 3185 bytes .../__pycache__/ansitowin32.cpython-39.pyc | Bin 0 -> 7651 bytes .../__pycache__/initialise.cpython-39.pyc | Bin 0 -> 1667 bytes .../colorama/__pycache__/win32.cpython-39.pyc | Bin 0 -> 3899 bytes .../__pycache__/winterm.cpython-39.pyc | Bin 0 -> 4621 bytes .../Lib/site-packages/colorama/ansi.py | 102 + .../Lib/site-packages/colorama/ansitowin32.py | 258 + .../Lib/site-packages/colorama/initialise.py | 80 + .../Lib/site-packages/colorama/win32.py | 152 + .../Lib/site-packages/colorama/winterm.py | 169 + .../site-packages/distutils-precedence.pth | 1 + .../Lib/site-packages/flask/__init__.py | 46 + .../Lib/site-packages/flask/__main__.py | 3 + .../flask/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1855 bytes .../flask/__pycache__/__main__.cpython-39.pyc | Bin 0 -> 186 bytes .../flask/__pycache__/app.cpython-39.pyc | Bin 0 -> 63206 bytes .../__pycache__/blueprints.cpython-39.pyc | Bin 0 -> 21905 bytes .../flask/__pycache__/cli.cpython-39.pyc | Bin 0 -> 27203 bytes .../flask/__pycache__/config.cpython-39.pyc | Bin 0 -> 11684 bytes .../flask/__pycache__/ctx.cpython-39.pyc | Bin 0 -> 15513 bytes .../__pycache__/debughelpers.cpython-39.pyc | Bin 0 -> 6454 bytes .../flask/__pycache__/globals.cpython-39.pyc | Bin 0 -> 1805 bytes .../flask/__pycache__/helpers.cpython-39.pyc | Bin 0 -> 27287 bytes .../flask/__pycache__/logging.cpython-39.pyc | Bin 0 -> 2422 bytes .../flask/__pycache__/scaffold.cpython-39.pyc | Bin 0 -> 24846 bytes .../flask/__pycache__/sessions.cpython-39.pyc | Bin 0 -> 13069 bytes .../flask/__pycache__/signals.cpython-39.pyc | Bin 0 -> 2342 bytes .../__pycache__/templating.cpython-39.pyc | Bin 0 -> 5523 bytes .../flask/__pycache__/testing.cpython-39.pyc | Bin 0 -> 8990 bytes .../flask/__pycache__/typing.cpython-39.pyc | Bin 0 -> 1747 bytes .../flask/__pycache__/views.cpython-39.pyc | Bin 0 -> 4954 bytes .../flask/__pycache__/wrappers.cpython-39.pyc | Bin 0 -> 4995 bytes .../pyvenv3.9/Lib/site-packages/flask/app.py | 2091 ++++ .../Lib/site-packages/flask/blueprints.py | 609 ++ .../pyvenv3.9/Lib/site-packages/flask/cli.py | 998 ++ .../Lib/site-packages/flask/config.py | 295 + .../pyvenv3.9/Lib/site-packages/flask/ctx.py | 480 + .../Lib/site-packages/flask/debughelpers.py | 172 + .../Lib/site-packages/flask/globals.py | 59 + .../Lib/site-packages/flask/helpers.py | 836 ++ .../Lib/site-packages/flask/json/__init__.py | 357 + .../json/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 11555 bytes .../flask/json/__pycache__/tag.cpython-39.pyc | Bin 0 -> 11437 bytes .../Lib/site-packages/flask/json/tag.py | 312 + .../Lib/site-packages/flask/logging.py | 74 + .../Lib/site-packages/flask/py.typed | 0 .../Lib/site-packages/flask/scaffold.py | 875 ++ .../Lib/site-packages/flask/sessions.py | 404 + .../Lib/site-packages/flask/signals.py | 56 + .../Lib/site-packages/flask/templating.py | 165 + .../Lib/site-packages/flask/testing.py | 280 + .../Lib/site-packages/flask/typing.py | 56 + .../Lib/site-packages/flask/views.py | 158 + .../Lib/site-packages/flask/wrappers.py | 167 + .../INSTALLER | 1 + .../LICENSE | 31 + .../METADATA | 33 + .../RECORD | 9 + .../REQUESTED | 0 .../flask_paginate-2021.10.26.dist-info/WHEEL | 6 + .../top_level.txt | 1 + .../site-packages/flask_paginate/__init__.py | 660 ++ .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 15372 bytes .../Lib/site-packages/gridfs/__init__.py | 941 ++ .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 34969 bytes .../gridfs/__pycache__/errors.cpython-39.pyc | Bin 0 -> 1031 bytes .../__pycache__/grid_file.cpython-39.pyc | Bin 0 -> 26645 bytes .../Lib/site-packages/gridfs/errors.py | 33 + .../Lib/site-packages/gridfs/grid_file.py | 856 ++ .../idna-3.3.dist-info/INSTALLER | 1 + .../idna-3.3.dist-info/LICENSE.md | 29 + .../site-packages/idna-3.3.dist-info/METADATA | 236 + .../site-packages/idna-3.3.dist-info/RECORD | 23 + .../site-packages/idna-3.3.dist-info/WHEEL | 5 + .../idna-3.3.dist-info/top_level.txt | 1 + .../Lib/site-packages/idna/__init__.py | 44 + .../idna/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 804 bytes .../idna/__pycache__/codec.cpython-39.pyc | Bin 0 -> 3041 bytes .../idna/__pycache__/compat.cpython-39.pyc | Bin 0 -> 723 bytes .../idna/__pycache__/core.cpython-39.pyc | Bin 0 -> 9719 bytes .../idna/__pycache__/idnadata.cpython-39.pyc | Bin 0 -> 23000 bytes .../idna/__pycache__/intranges.cpython-39.pyc | Bin 0 -> 1954 bytes .../__pycache__/package_data.cpython-39.pyc | Bin 0 -> 168 bytes .../idna/__pycache__/uts46data.cpython-39.pyc | Bin 0 -> 151701 bytes .../pyvenv3.9/Lib/site-packages/idna/codec.py | 112 + .../Lib/site-packages/idna/compat.py | 13 + .../pyvenv3.9/Lib/site-packages/idna/core.py | 397 + .../Lib/site-packages/idna/idnadata.py | 2137 +++++ .../Lib/site-packages/idna/intranges.py | 54 + .../Lib/site-packages/idna/package_data.py | 2 + .../pyvenv3.9/Lib/site-packages/idna/py.typed | 0 .../Lib/site-packages/idna/uts46data.py | 8512 +++++++++++++++++ .../itsdangerous-2.0.1.dist-info/INSTALLER | 1 + .../itsdangerous-2.0.1.dist-info/LICENSE.rst | 28 + .../itsdangerous-2.0.1.dist-info/METADATA | 96 + .../itsdangerous-2.0.1.dist-info/RECORD | 25 + .../itsdangerous-2.0.1.dist-info/WHEEL | 5 + .../top_level.txt | 1 + .../site-packages/itsdangerous/__init__.py | 22 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 981 bytes .../__pycache__/_json.cpython-39.pyc | Bin 0 -> 1515 bytes .../__pycache__/encoding.cpython-39.pyc | Bin 0 -> 1827 bytes .../__pycache__/exc.cpython-39.pyc | Bin 0 -> 3408 bytes .../__pycache__/jws.cpython-39.pyc | Bin 0 -> 7555 bytes .../__pycache__/serializer.cpython-39.pyc | Bin 0 -> 9710 bytes .../__pycache__/signer.cpython-39.pyc | Bin 0 -> 8407 bytes .../__pycache__/timed.cpython-39.pyc | Bin 0 -> 6328 bytes .../__pycache__/url_safe.cpython-39.pyc | Bin 0 -> 2676 bytes .../Lib/site-packages/itsdangerous/_json.py | 34 + .../site-packages/itsdangerous/encoding.py | 54 + .../Lib/site-packages/itsdangerous/exc.py | 107 + .../Lib/site-packages/itsdangerous/jws.py | 259 + .../Lib/site-packages/itsdangerous/py.typed | 0 .../site-packages/itsdangerous/serializer.py | 295 + .../Lib/site-packages/itsdangerous/signer.py | 257 + .../Lib/site-packages/itsdangerous/timed.py | 227 + .../site-packages/itsdangerous/url_safe.py | 80 + .../Lib/site-packages/jinja2/__init__.py | 45 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1880 bytes .../__pycache__/_identifier.cpython-39.pyc | Bin 0 -> 1867 bytes .../__pycache__/async_utils.cpython-39.pyc | Bin 0 -> 2280 bytes .../jinja2/__pycache__/bccache.cpython-39.pyc | Bin 0 -> 13259 bytes .../__pycache__/compiler.cpython-39.pyc | Bin 0 -> 54188 bytes .../__pycache__/constants.cpython-39.pyc | Bin 0 -> 1511 bytes .../jinja2/__pycache__/debug.cpython-39.pyc | Bin 0 -> 5504 bytes .../__pycache__/defaults.cpython-39.pyc | Bin 0 -> 1311 bytes .../__pycache__/environment.cpython-39.pyc | Bin 0 -> 53417 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 5552 bytes .../jinja2/__pycache__/ext.cpython-39.pyc | Bin 0 -> 26318 bytes .../jinja2/__pycache__/filters.cpython-39.pyc | Bin 0 -> 49984 bytes .../__pycache__/idtracking.cpython-39.pyc | Bin 0 -> 11085 bytes .../jinja2/__pycache__/lexer.cpython-39.pyc | Bin 0 -> 20282 bytes .../jinja2/__pycache__/loaders.cpython-39.pyc | Bin 0 -> 20245 bytes .../jinja2/__pycache__/meta.cpython-39.pyc | Bin 0 -> 3769 bytes .../__pycache__/nativetypes.cpython-39.pyc | Bin 0 -> 4758 bytes .../jinja2/__pycache__/nodes.cpython-39.pyc | Bin 0 -> 40977 bytes .../__pycache__/optimizer.cpython-39.pyc | Bin 0 -> 1900 bytes .../jinja2/__pycache__/parser.cpython-39.pyc | Bin 0 -> 27560 bytes .../jinja2/__pycache__/runtime.cpython-39.pyc | Bin 0 -> 33085 bytes .../jinja2/__pycache__/sandbox.cpython-39.pyc | Bin 0 -> 11891 bytes .../jinja2/__pycache__/tests.cpython-39.pyc | Bin 0 -> 6543 bytes .../jinja2/__pycache__/utils.cpython-39.pyc | Bin 0 -> 27417 bytes .../jinja2/__pycache__/visitor.cpython-39.pyc | Bin 0 -> 3865 bytes .../Lib/site-packages/jinja2/_identifier.py | 6 + .../Lib/site-packages/jinja2/async_utils.py | 68 + .../Lib/site-packages/jinja2/bccache.py | 364 + .../Lib/site-packages/jinja2/compiler.py | 1957 ++++ .../Lib/site-packages/jinja2/constants.py | 20 + .../Lib/site-packages/jinja2/debug.py | 279 + .../Lib/site-packages/jinja2/defaults.py | 48 + .../Lib/site-packages/jinja2/environment.py | 1674 ++++ .../Lib/site-packages/jinja2/exceptions.py | 166 + .../pyvenv3.9/Lib/site-packages/jinja2/ext.py | 879 ++ .../Lib/site-packages/jinja2/filters.py | 1824 ++++ .../Lib/site-packages/jinja2/idtracking.py | 318 + .../Lib/site-packages/jinja2/lexer.py | 869 ++ .../Lib/site-packages/jinja2/loaders.py | 644 ++ .../Lib/site-packages/jinja2/meta.py | 111 + .../Lib/site-packages/jinja2/nativetypes.py | 118 + .../Lib/site-packages/jinja2/nodes.py | 1205 +++ .../Lib/site-packages/jinja2/optimizer.py | 47 + .../Lib/site-packages/jinja2/parser.py | 1040 ++ .../Lib/site-packages/jinja2/py.typed | 0 .../Lib/site-packages/jinja2/runtime.py | 1104 +++ .../Lib/site-packages/jinja2/sandbox.py | 428 + .../Lib/site-packages/jinja2/tests.py | 255 + .../Lib/site-packages/jinja2/utils.py | 854 ++ .../Lib/site-packages/jinja2/visitor.py | 92 + .../joblib-1.1.0.dist-info/INSTALLER | 1 + .../joblib-1.1.0.dist-info/LICENSE.txt | 29 + .../joblib-1.1.0.dist-info/METADATA | 165 + .../joblib-1.1.0.dist-info/RECORD | 233 + .../joblib-1.1.0.dist-info/WHEEL | 6 + .../joblib-1.1.0.dist-info/top_level.txt | 1 + .../Lib/site-packages/joblib/__init__.py | 139 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 4511 bytes .../joblib/__pycache__/_dask.cpython-39.pyc | Bin 0 -> 10625 bytes .../_deprecated_format_stack.cpython-39.pyc | Bin 0 -> 8235 bytes .../_deprecated_my_exceptions.cpython-39.pyc | Bin 0 -> 2861 bytes .../_memmapping_reducer.cpython-39.pyc | Bin 0 -> 16255 bytes .../_multiprocessing_helpers.cpython-39.pyc | Bin 0 -> 1227 bytes .../_parallel_backends.cpython-39.pyc | Bin 0 -> 19428 bytes .../_store_backends.cpython-39.pyc | Bin 0 -> 14102 bytes .../__pycache__/backports.cpython-39.pyc | Bin 0 -> 2574 bytes .../__pycache__/compressor.cpython-39.pyc | Bin 0 -> 16685 bytes .../joblib/__pycache__/disk.cpython-39.pyc | Bin 0 -> 3069 bytes .../__pycache__/executor.cpython-39.pyc | Bin 0 -> 3252 bytes .../__pycache__/format_stack.cpython-39.pyc | Bin 0 -> 855 bytes .../__pycache__/func_inspect.cpython-39.pyc | Bin 0 -> 8855 bytes .../joblib/__pycache__/hashing.cpython-39.pyc | Bin 0 -> 6329 bytes .../joblib/__pycache__/logger.cpython-39.pyc | Bin 0 -> 4036 bytes .../joblib/__pycache__/memory.cpython-39.pyc | Bin 0 -> 29077 bytes .../__pycache__/my_exceptions.cpython-39.pyc | Bin 0 -> 1145 bytes .../__pycache__/numpy_pickle.cpython-39.pyc | Bin 0 -> 15776 bytes .../numpy_pickle_compat.cpython-39.pyc | Bin 0 -> 7083 bytes .../numpy_pickle_utils.cpython-39.pyc | Bin 0 -> 6550 bytes .../__pycache__/parallel.cpython-39.pyc | Bin 0 -> 32644 bytes .../joblib/__pycache__/pool.cpython-39.pyc | Bin 0 -> 12570 bytes .../joblib/__pycache__/testing.cpython-39.pyc | Bin 0 -> 2075 bytes .../Lib/site-packages/joblib/_dask.py | 364 + .../joblib/_deprecated_format_stack.py | 397 + .../joblib/_deprecated_my_exceptions.py | 115 + .../joblib/_memmapping_reducer.py | 664 ++ .../joblib/_multiprocessing_helpers.py | 52 + .../joblib/_parallel_backends.py | 610 ++ .../site-packages/joblib/_store_backends.py | 414 + .../Lib/site-packages/joblib/backports.py | 78 + .../Lib/site-packages/joblib/compressor.py | 570 ++ .../Lib/site-packages/joblib/disk.py | 136 + .../Lib/site-packages/joblib/executor.py | 120 + .../joblib/externals/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 157 bytes .../joblib/externals/cloudpickle/__init__.py | 11 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 377 bytes .../__pycache__/cloudpickle.cpython-39.pyc | Bin 0 -> 25820 bytes .../cloudpickle_fast.cpython-39.pyc | Bin 0 -> 20702 bytes .../__pycache__/compat.cpython-39.pyc | Bin 0 -> 394 bytes .../externals/cloudpickle/cloudpickle.py | 973 ++ .../externals/cloudpickle/cloudpickle_fast.py | 809 ++ .../joblib/externals/cloudpickle/compat.py | 13 + .../joblib/externals/loky/__init__.py | 25 + .../loky/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1142 bytes .../loky/__pycache__/_base.cpython-39.pyc | Bin 0 -> 21781 bytes .../cloudpickle_wrapper.cpython-39.pyc | Bin 0 -> 3928 bytes .../__pycache__/initializers.cpython-39.pyc | Bin 0 -> 2357 bytes .../process_executor.cpython-39.pyc | Bin 0 -> 31727 bytes .../reusable_executor.cpython-39.pyc | Bin 0 -> 7480 bytes .../joblib/externals/loky/_base.py | 627 ++ .../joblib/externals/loky/backend/__init__.py | 16 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 575 bytes .../_posix_reduction.cpython-39.pyc | Bin 0 -> 2074 bytes .../__pycache__/_posix_wait.cpython-39.pyc | Bin 0 -> 2517 bytes .../__pycache__/_win_reduction.cpython-39.pyc | Bin 0 -> 2896 bytes .../__pycache__/_win_wait.cpython-39.pyc | Bin 0 -> 1344 bytes .../backend/__pycache__/compat.cpython-39.pyc | Bin 0 -> 820 bytes .../__pycache__/compat_posix.cpython-39.pyc | Bin 0 -> 316 bytes .../__pycache__/compat_win32.cpython-39.pyc | Bin 0 -> 1167 bytes .../__pycache__/context.cpython-39.pyc | Bin 0 -> 10548 bytes .../__pycache__/fork_exec.cpython-39.pyc | Bin 0 -> 1344 bytes .../__pycache__/managers.cpython-39.pyc | Bin 0 -> 1510 bytes .../popen_loky_posix.cpython-39.pyc | Bin 0 -> 5638 bytes .../popen_loky_win32.cpython-39.pyc | Bin 0 -> 4273 bytes .../__pycache__/process.cpython-39.pyc | Bin 0 -> 3638 bytes .../backend/__pycache__/queues.cpython-39.pyc | Bin 0 -> 5925 bytes .../__pycache__/reduction.cpython-39.pyc | Bin 0 -> 6420 bytes .../resource_tracker.cpython-39.pyc | Bin 0 -> 7961 bytes .../__pycache__/semlock.cpython-39.pyc | Bin 0 -> 6719 bytes .../backend/__pycache__/spawn.cpython-39.pyc | Bin 0 -> 5227 bytes .../__pycache__/synchronize.cpython-39.pyc | Bin 0 -> 10106 bytes .../backend/__pycache__/utils.cpython-39.pyc | Bin 0 -> 4151 bytes .../loky/backend/_posix_reduction.py | 76 + .../externals/loky/backend/_posix_wait.py | 105 + .../externals/loky/backend/_win_reduction.py | 99 + .../externals/loky/backend/_win_wait.py | 58 + .../joblib/externals/loky/backend/compat.py | 41 + .../externals/loky/backend/compat_posix.py | 13 + .../externals/loky/backend/compat_win32.py | 46 + .../joblib/externals/loky/backend/context.py | 367 + .../externals/loky/backend/fork_exec.py | 48 + .../joblib/externals/loky/backend/managers.py | 51 + .../loky/backend/popen_loky_posix.py | 215 + .../loky/backend/popen_loky_win32.py | 173 + .../joblib/externals/loky/backend/process.py | 108 + .../joblib/externals/loky/backend/queues.py | 247 + .../externals/loky/backend/reduction.py | 280 + .../loky/backend/resource_tracker.py | 380 + .../joblib/externals/loky/backend/semlock.py | 274 + .../joblib/externals/loky/backend/spawn.py | 258 + .../externals/loky/backend/synchronize.py | 387 + .../joblib/externals/loky/backend/utils.py | 172 + .../externals/loky/cloudpickle_wrapper.py | 113 + .../joblib/externals/loky/initializers.py | 78 + .../joblib/externals/loky/process_executor.py | 1195 +++ .../externals/loky/reusable_executor.py | 232 + .../Lib/site-packages/joblib/format_stack.py | 36 + .../Lib/site-packages/joblib/func_inspect.py | 365 + .../Lib/site-packages/joblib/hashing.py | 266 + .../Lib/site-packages/joblib/logger.py | 156 + .../Lib/site-packages/joblib/memory.py | 1058 ++ .../Lib/site-packages/joblib/my_exceptions.py | 35 + .../Lib/site-packages/joblib/numpy_pickle.py | 588 ++ .../joblib/numpy_pickle_compat.py | 243 + .../joblib/numpy_pickle_utils.py | 253 + .../Lib/site-packages/joblib/parallel.py | 1074 +++ .../Lib/site-packages/joblib/pool.py | 352 + .../Lib/site-packages/joblib/test/__init__.py | 2 + .../test/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 234 bytes .../test/__pycache__/common.cpython-39.pyc | Bin 0 -> 3154 bytes .../__pycache__/test_backports.cpython-39.pyc | Bin 0 -> 1582 bytes .../test/__pycache__/test_dask.cpython-39.pyc | Bin 0 -> 20035 bytes .../test_deprecated_objects.cpython-39.pyc | Bin 0 -> 1355 bytes .../test/__pycache__/test_disk.cpython-39.pyc | Bin 0 -> 2091 bytes .../test_format_stack.cpython-39.pyc | Bin 0 -> 3823 bytes .../test_func_inspect.cpython-39.pyc | Bin 0 -> 9363 bytes ...nc_inspect_special_encoding.cpython-39.pyc | Bin 0 -> 309 bytes .../__pycache__/test_hashing.cpython-39.pyc | Bin 0 -> 13127 bytes .../test/__pycache__/test_init.cpython-39.pyc | Bin 0 -> 395 bytes .../__pycache__/test_logger.cpython-39.pyc | Bin 0 -> 740 bytes .../test_memmapping.cpython-39.pyc | Bin 0 -> 30350 bytes .../__pycache__/test_memory.cpython-39.pyc | Bin 0 -> 36816 bytes .../__pycache__/test_module.cpython-39.pyc | Bin 0 -> 1967 bytes .../test_my_exceptions.cpython-39.pyc | Bin 0 -> 2232 bytes .../test_numpy_pickle.cpython-39.pyc | Bin 0 -> 29065 bytes .../test_numpy_pickle_compat.cpython-39.pyc | Bin 0 -> 698 bytes .../test_numpy_pickle_utils.cpython-39.pyc | Bin 0 -> 626 bytes .../__pycache__/test_parallel.cpython-39.pyc | Bin 0 -> 57969 bytes .../test_store_backends.cpython-39.pyc | Bin 0 -> 2285 bytes .../__pycache__/test_testing.cpython-39.pyc | Bin 0 -> 2335 bytes .../test/__pycache__/testutils.cpython-39.pyc | Bin 0 -> 540 bytes .../Lib/site-packages/joblib/test/common.py | 114 + .../joblib/test/data/__init__.py | 0 .../data/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 157 bytes .../create_numpy_pickle.cpython-39.pyc | Bin 0 -> 2716 bytes .../joblib/test/data/create_numpy_pickle.py | 94 + ...blib_0.10.0_compressed_pickle_py27_np16.gz | Bin 0 -> 769 bytes ...blib_0.10.0_compressed_pickle_py27_np17.gz | Bin 0 -> 757 bytes ...blib_0.10.0_compressed_pickle_py33_np18.gz | Bin 0 -> 792 bytes ...blib_0.10.0_compressed_pickle_py34_np19.gz | Bin 0 -> 794 bytes ...blib_0.10.0_compressed_pickle_py35_np19.gz | Bin 0 -> 790 bytes .../data/joblib_0.10.0_pickle_py27_np17.pkl | Bin 0 -> 986 bytes .../joblib_0.10.0_pickle_py27_np17.pkl.bz2 | Bin 0 -> 997 bytes .../joblib_0.10.0_pickle_py27_np17.pkl.gzip | Bin 0 -> 798 bytes .../joblib_0.10.0_pickle_py27_np17.pkl.lzma | Bin 0 -> 660 bytes .../joblib_0.10.0_pickle_py27_np17.pkl.xz | Bin 0 -> 712 bytes .../data/joblib_0.10.0_pickle_py33_np18.pkl | Bin 0 -> 1068 bytes .../joblib_0.10.0_pickle_py33_np18.pkl.bz2 | Bin 0 -> 1000 bytes .../joblib_0.10.0_pickle_py33_np18.pkl.gzip | Bin 0 -> 831 bytes .../joblib_0.10.0_pickle_py33_np18.pkl.lzma | Bin 0 -> 694 bytes .../joblib_0.10.0_pickle_py33_np18.pkl.xz | Bin 0 -> 752 bytes .../data/joblib_0.10.0_pickle_py34_np19.pkl | Bin 0 -> 1068 bytes .../joblib_0.10.0_pickle_py34_np19.pkl.bz2 | Bin 0 -> 1021 bytes .../joblib_0.10.0_pickle_py34_np19.pkl.gzip | Bin 0 -> 831 bytes .../joblib_0.10.0_pickle_py34_np19.pkl.lzma | Bin 0 -> 697 bytes .../joblib_0.10.0_pickle_py34_np19.pkl.xz | Bin 0 -> 752 bytes .../data/joblib_0.10.0_pickle_py35_np19.pkl | Bin 0 -> 1068 bytes .../joblib_0.10.0_pickle_py35_np19.pkl.bz2 | Bin 0 -> 1005 bytes .../joblib_0.10.0_pickle_py35_np19.pkl.gzip | Bin 0 -> 833 bytes .../joblib_0.10.0_pickle_py35_np19.pkl.lzma | Bin 0 -> 701 bytes .../joblib_0.10.0_pickle_py35_np19.pkl.xz | Bin 0 -> 752 bytes ...lib_0.11.0_compressed_pickle_py36_np111.gz | Bin 0 -> 800 bytes .../data/joblib_0.11.0_pickle_py36_np111.pkl | Bin 0 -> 1068 bytes .../joblib_0.11.0_pickle_py36_np111.pkl.bz2 | Bin 0 -> 991 bytes .../joblib_0.11.0_pickle_py36_np111.pkl.gzip | Bin 0 -> 800 bytes .../joblib_0.11.0_pickle_py36_np111.pkl.lzma | Bin 0 -> 715 bytes .../joblib_0.11.0_pickle_py36_np111.pkl.xz | Bin 0 -> 752 bytes ...oblib_0.8.4_compressed_pickle_py27_np17.gz | Bin 0 -> 659 bytes ...oblib_0.9.2_compressed_pickle_py27_np16.gz | Bin 0 -> 658 bytes ...oblib_0.9.2_compressed_pickle_py27_np17.gz | Bin 0 -> 658 bytes ...oblib_0.9.2_compressed_pickle_py34_np19.gz | Bin 0 -> 673 bytes ...oblib_0.9.2_compressed_pickle_py35_np19.gz | Bin 0 -> 673 bytes .../data/joblib_0.9.2_pickle_py27_np16.pkl | Bin 0 -> 670 bytes .../joblib_0.9.2_pickle_py27_np16.pkl_01.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py27_np16.pkl_02.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py27_np16.pkl_03.npy | Bin 0 -> 236 bytes .../joblib_0.9.2_pickle_py27_np16.pkl_04.npy | Bin 0 -> 104 bytes .../data/joblib_0.9.2_pickle_py27_np17.pkl | Bin 0 -> 670 bytes .../joblib_0.9.2_pickle_py27_np17.pkl_01.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py27_np17.pkl_02.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py27_np17.pkl_03.npy | Bin 0 -> 236 bytes .../joblib_0.9.2_pickle_py27_np17.pkl_04.npy | Bin 0 -> 104 bytes .../data/joblib_0.9.2_pickle_py33_np18.pkl | Bin 0 -> 691 bytes .../joblib_0.9.2_pickle_py33_np18.pkl_01.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py33_np18.pkl_02.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py33_np18.pkl_03.npy | Bin 0 -> 307 bytes .../joblib_0.9.2_pickle_py33_np18.pkl_04.npy | Bin 0 -> 104 bytes .../data/joblib_0.9.2_pickle_py34_np19.pkl | Bin 0 -> 691 bytes .../joblib_0.9.2_pickle_py34_np19.pkl_01.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py34_np19.pkl_02.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py34_np19.pkl_03.npy | Bin 0 -> 307 bytes .../joblib_0.9.2_pickle_py34_np19.pkl_04.npy | Bin 0 -> 104 bytes .../data/joblib_0.9.2_pickle_py35_np19.pkl | Bin 0 -> 691 bytes .../joblib_0.9.2_pickle_py35_np19.pkl_01.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py35_np19.pkl_02.npy | Bin 0 -> 120 bytes .../joblib_0.9.2_pickle_py35_np19.pkl_03.npy | Bin 0 -> 307 bytes .../joblib_0.9.2_pickle_py35_np19.pkl_04.npy | Bin 0 -> 104 bytes ..._compressed_cache_size_pickle_py35_np19.gz | Bin 0 -> 802 bytes ...ed_cache_size_pickle_py35_np19.gz_01.npy.z | Bin 0 -> 43 bytes ...ed_cache_size_pickle_py35_np19.gz_02.npy.z | Bin 0 -> 43 bytes ...ed_cache_size_pickle_py35_np19.gz_03.npy.z | Bin 0 -> 37 bytes .../joblib/test/test_backports.py | 35 + .../site-packages/joblib/test/test_dask.py | 464 + .../joblib/test/test_deprecated_objects.py | 31 + .../site-packages/joblib/test/test_disk.py | 71 + .../joblib/test/test_format_stack.py | 129 + .../joblib/test/test_func_inspect.py | 290 + .../test_func_inspect_special_encoding.py | 10 + .../site-packages/joblib/test/test_hashing.py | 497 + .../site-packages/joblib/test/test_init.py | 14 + .../site-packages/joblib/test/test_logger.py | 32 + .../joblib/test/test_memmapping.py | 1162 +++ .../site-packages/joblib/test/test_memory.py | 1340 +++ .../site-packages/joblib/test/test_module.py | 50 + .../joblib/test/test_my_exceptions.py | 60 + .../joblib/test/test_numpy_pickle.py | 1058 ++ .../joblib/test/test_numpy_pickle_compat.py | 18 + .../joblib/test/test_numpy_pickle_utils.py | 10 + .../joblib/test/test_parallel.py | 1690 ++++ .../joblib/test/test_store_backends.py | 56 + .../site-packages/joblib/test/test_testing.py | 73 + .../site-packages/joblib/test/testutils.py | 8 + .../Lib/site-packages/joblib/testing.py | 77 + .../lxml-4.6.3.dist-info/INSTALLER | 1 + .../lxml-4.6.3.dist-info/LICENSE.txt | 29 + .../lxml-4.6.3.dist-info/LICENSES.txt | 29 + .../lxml-4.6.3.dist-info/METADATA | 82 + .../site-packages/lxml-4.6.3.dist-info/RECORD | 169 + .../lxml-4.6.3.dist-info/REQUESTED | 0 .../site-packages/lxml-4.6.3.dist-info/WHEEL | 5 + .../lxml-4.6.3.dist-info/top_level.txt | 1 + .../Lib/site-packages/lxml/ElementInclude.py | 244 + .../Lib/site-packages/lxml/__init__.py | 23 + .../__pycache__/ElementInclude.cpython-39.pyc | Bin 0 -> 3814 bytes .../lxml/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 668 bytes .../__pycache__/_elementpath.cpython-39.pyc | Bin 0 -> 6386 bytes .../lxml/__pycache__/builder.cpython-39.pyc | Bin 0 -> 5826 bytes .../lxml/__pycache__/cssselect.cpython-39.pyc | Bin 0 -> 3609 bytes .../__pycache__/doctestcompare.cpython-39.pyc | Bin 0 -> 13918 bytes .../__pycache__/pyclasslookup.cpython-39.pyc | Bin 0 -> 209 bytes .../lxml/__pycache__/sax.cpython-39.pyc | Bin 0 -> 8119 bytes .../__pycache__/usedoctest.cpython-39.pyc | Bin 0 -> 399 bytes .../lxml/_elementpath.cp39-win_amd64.pyd | Bin 0 -> 144896 bytes .../Lib/site-packages/lxml/_elementpath.py | 345 + .../lxml/builder.cp39-win_amd64.pyd | Bin 0 -> 81920 bytes .../Lib/site-packages/lxml/builder.py | 239 + .../Lib/site-packages/lxml/cssselect.py | 102 + .../Lib/site-packages/lxml/doctestcompare.py | 507 + .../lxml/etree.cp39-win_amd64.pyd | Bin 0 -> 3859968 bytes .../pyvenv3.9/Lib/site-packages/lxml/etree.h | 224 + .../Lib/site-packages/lxml/etree_api.h | 219 + .../site-packages/lxml/html/ElementSoup.py | 10 + .../Lib/site-packages/lxml/html/__init__.py | 1948 ++++ .../__pycache__/ElementSoup.cpython-39.pyc | Bin 0 -> 495 bytes .../html/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 56866 bytes .../__pycache__/_diffcommand.cpython-39.pyc | Bin 0 -> 2265 bytes .../__pycache__/_html5builder.cpython-39.pyc | Bin 0 -> 3577 bytes .../html/__pycache__/_setmixin.cpython-39.pyc | Bin 0 -> 2078 bytes .../html/__pycache__/builder.cpython-39.pyc | Bin 0 -> 2928 bytes .../html/__pycache__/clean.cpython-39.pyc | Bin 0 -> 17414 bytes .../lxml/html/__pycache__/defs.cpython-39.pyc | Bin 0 -> 2796 bytes .../lxml/html/__pycache__/diff.cpython-39.pyc | Bin 0 -> 24023 bytes .../html/__pycache__/formfill.cpython-39.pyc | Bin 0 -> 7372 bytes .../__pycache__/html5parser.cpython-39.pyc | Bin 0 -> 6453 bytes .../__pycache__/soupparser.cpython-39.pyc | Bin 0 -> 7978 bytes .../__pycache__/usedoctest.cpython-39.pyc | Bin 0 -> 421 bytes .../site-packages/lxml/html/_diffcommand.py | 88 + .../site-packages/lxml/html/_html5builder.py | 100 + .../Lib/site-packages/lxml/html/_setmixin.py | 56 + .../Lib/site-packages/lxml/html/builder.py | 133 + .../lxml/html/clean.cp39-win_amd64.pyd | Bin 0 -> 189952 bytes .../Lib/site-packages/lxml/html/clean.py | 779 ++ .../Lib/site-packages/lxml/html/defs.py | 135 + .../lxml/html/diff.cp39-win_amd64.pyd | Bin 0 -> 254464 bytes .../Lib/site-packages/lxml/html/diff.py | 884 ++ .../Lib/site-packages/lxml/html/formfill.py | 299 + .../site-packages/lxml/html/html5parser.py | 260 + .../Lib/site-packages/lxml/html/soupparser.py | 314 + .../Lib/site-packages/lxml/html/usedoctest.py | 13 + .../site-packages/lxml/includes/__init__.pxd | 0 .../site-packages/lxml/includes/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 154 bytes .../Lib/site-packages/lxml/includes/c14n.pxd | 26 + .../site-packages/lxml/includes/config.pxd | 3 + .../site-packages/lxml/includes/dtdvalid.pxd | 18 + .../site-packages/lxml/includes/etree_defs.h | 418 + .../lxml/includes/etreepublic.pxd | 237 + .../lxml/includes/htmlparser.pxd | 56 + .../lxml/includes/libexslt/exslt.h | 102 + .../lxml/includes/libexslt/exsltconfig.h | 73 + .../lxml/includes/libexslt/exsltexports.h | 140 + .../lxml/includes/libexslt/libexslt.h | 29 + .../lxml/includes/libxml/DOCBparser.h | 96 + .../lxml/includes/libxml/HTMLparser.h | 306 + .../lxml/includes/libxml/HTMLtree.h | 147 + .../site-packages/lxml/includes/libxml/SAX.h | 173 + .../site-packages/lxml/includes/libxml/SAX2.h | 178 + .../site-packages/lxml/includes/libxml/c14n.h | 126 + .../lxml/includes/libxml/catalog.h | 182 + .../lxml/includes/libxml/chvalid.h | 230 + .../lxml/includes/libxml/debugXML.h | 217 + .../site-packages/lxml/includes/libxml/dict.h | 86 + .../lxml/includes/libxml/encoding.h | 240 + .../lxml/includes/libxml/entities.h | 151 + .../lxml/includes/libxml/globals.h | 509 + .../site-packages/lxml/includes/libxml/hash.h | 233 + .../site-packages/lxml/includes/libxml/list.h | 137 + .../lxml/includes/libxml/nanoftp.h | 163 + .../lxml/includes/libxml/nanohttp.h | 81 + .../lxml/includes/libxml/parser.h | 1241 +++ .../lxml/includes/libxml/parserInternals.h | 644 ++ .../lxml/includes/libxml/pattern.h | 100 + .../lxml/includes/libxml/relaxng.h | 217 + .../lxml/includes/libxml/schemasInternals.h | 958 ++ .../lxml/includes/libxml/schematron.h | 142 + .../lxml/includes/libxml/threads.h | 84 + .../site-packages/lxml/includes/libxml/tree.h | 1311 +++ .../site-packages/lxml/includes/libxml/uri.h | 94 + .../lxml/includes/libxml/valid.h | 458 + .../lxml/includes/libxml/xinclude.h | 129 + .../lxml/includes/libxml/xlink.h | 189 + .../lxml/includes/libxml/xmlIO.h | 366 + .../lxml/includes/libxml/xmlautomata.h | 146 + .../lxml/includes/libxml/xmlerror.h | 945 ++ .../lxml/includes/libxml/xmlexports.h | 162 + .../lxml/includes/libxml/xmlmemory.h | 224 + .../lxml/includes/libxml/xmlmodule.h | 57 + .../lxml/includes/libxml/xmlreader.h | 428 + .../lxml/includes/libxml/xmlregexp.h | 222 + .../lxml/includes/libxml/xmlsave.h | 88 + .../lxml/includes/libxml/xmlschemas.h | 246 + .../lxml/includes/libxml/xmlschemastypes.h | 151 + .../lxml/includes/libxml/xmlstring.h | 140 + .../lxml/includes/libxml/xmlunicode.h | 202 + .../lxml/includes/libxml/xmlversion.h | 489 + .../lxml/includes/libxml/xmlwriter.h | 488 + .../lxml/includes/libxml/xpath.h | 557 ++ .../lxml/includes/libxml/xpathInternals.h | 632 ++ .../lxml/includes/libxml/xpointer.h | 114 + .../lxml/includes/libxslt/attributes.h | 38 + .../lxml/includes/libxslt/documents.h | 93 + .../lxml/includes/libxslt/extensions.h | 262 + .../lxml/includes/libxslt/extra.h | 72 + .../lxml/includes/libxslt/functions.h | 78 + .../lxml/includes/libxslt/imports.h | 75 + .../lxml/includes/libxslt/keys.h | 53 + .../lxml/includes/libxslt/libxslt.h | 36 + .../lxml/includes/libxslt/namespaces.h | 68 + .../lxml/includes/libxslt/numbersInternals.h | 73 + .../lxml/includes/libxslt/preproc.h | 43 + .../lxml/includes/libxslt/security.h | 104 + .../lxml/includes/libxslt/templates.h | 77 + .../lxml/includes/libxslt/transform.h | 207 + .../lxml/includes/libxslt/trio.h | 216 + .../lxml/includes/libxslt/triodef.h | 220 + .../lxml/includes/libxslt/variables.h | 126 + .../lxml/includes/libxslt/win32config.h | 129 + .../lxml/includes/libxslt/xslt.h | 110 + .../lxml/includes/libxslt/xsltInternals.h | 1982 ++++ .../lxml/includes/libxslt/xsltconfig.h | 183 + .../lxml/includes/libxslt/xsltexports.h | 142 + .../lxml/includes/libxslt/xsltlocale.h | 67 + .../lxml/includes/libxslt/xsltutils.h | 313 + .../lxml/includes/lxml-version.h | 3 + .../site-packages/lxml/includes/relaxng.pxd | 64 + .../lxml/includes/schematron.pxd | 34 + .../Lib/site-packages/lxml/includes/tree.pxd | 480 + .../Lib/site-packages/lxml/includes/uri.pxd | 5 + .../site-packages/lxml/includes/xinclude.pxd | 22 + .../site-packages/lxml/includes/xmlerror.pxd | 851 ++ .../site-packages/lxml/includes/xmlparser.pxd | 249 + .../site-packages/lxml/includes/xmlschema.pxd | 35 + .../Lib/site-packages/lxml/includes/xpath.pxd | 135 + .../Lib/site-packages/lxml/includes/xslt.pxd | 191 + .../lxml/isoschematron/__init__.py | 334 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 9643 bytes .../resources/rng/iso-schematron.rng | 709 ++ .../resources/xsl/RNG2Schtrn.xsl | 75 + .../resources/xsl/XSD2Schtrn.xsl | 77 + .../iso_abstract_expand.xsl | 313 + .../iso-schematron-xslt1/iso_dsdl_include.xsl | 1160 +++ .../iso_schematron_message.xsl | 55 + .../iso_schematron_skeleton_for_xslt1.xsl | 1796 ++++ .../iso_svrl_for_xslt1.xsl | 588 ++ .../xsl/iso-schematron-xslt1/readme.txt | 84 + .../Lib/site-packages/lxml/lxml.etree.h | 224 + .../Lib/site-packages/lxml/lxml.etree_api.h | 219 + .../lxml/objectify.cp39-win_amd64.pyd | Bin 0 -> 1676800 bytes .../Lib/site-packages/lxml/pyclasslookup.py | 3 + .../site-packages/lxml/sax.cp39-win_amd64.pyd | Bin 0 -> 125440 bytes .../pyvenv3.9/Lib/site-packages/lxml/sax.py | 278 + .../Lib/site-packages/lxml/usedoctest.py | 13 + .../Lib/site-packages/markupsafe/__init__.py | 288 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 10656 bytes .../__pycache__/_native.cpython-39.pyc | Bin 0 -> 2303 bytes .../Lib/site-packages/markupsafe/_native.py | 75 + .../markupsafe/_speedups.cp39-win_amd64.pyd | Bin 0 -> 16384 bytes .../site-packages/markupsafe/_speedups.pyi | 9 + .../Lib/site-packages/markupsafe/py.typed | 0 .../nltk-3.6.5.dist-info/AUTHORS.md | 299 + .../nltk-3.6.5.dist-info/INSTALLER | 1 + .../nltk-3.6.5.dist-info/LICENSE.txt | 202 + .../nltk-3.6.5.dist-info/METADATA | 71 + .../nltk-3.6.5.dist-info/README.md | 50 + .../site-packages/nltk-3.6.5.dist-info/RECORD | 763 ++ .../nltk-3.6.5.dist-info/REQUESTED | 0 .../site-packages/nltk-3.6.5.dist-info/WHEEL | 5 + .../nltk-3.6.5.dist-info/entry_points.txt | 3 + .../nltk-3.6.5.dist-info/top_level.txt | 1 + .../pyvenv3.9/Lib/site-packages/nltk/VERSION | 1 + .../Lib/site-packages/nltk/__init__.py | 208 + .../nltk/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 4825 bytes .../nltk/__pycache__/book.cpython-39.pyc | Bin 0 -> 2974 bytes .../nltk/__pycache__/cli.cpython-39.pyc | Bin 0 -> 1611 bytes .../__pycache__/collections.cpython-39.pyc | Bin 0 -> 23359 bytes .../__pycache__/collocations.cpython-39.pyc | Bin 0 -> 14912 bytes .../nltk/__pycache__/compat.cpython-39.pyc | Bin 0 -> 1110 bytes .../nltk/__pycache__/data.cpython-39.pyc | Bin 0 -> 38548 bytes .../__pycache__/decorators.cpython-39.pyc | Bin 0 -> 6405 bytes .../__pycache__/downloader.cpython-39.pyc | Bin 0 -> 61353 bytes .../__pycache__/featstruct.cpython-39.pyc | Bin 0 -> 74138 bytes .../nltk/__pycache__/grammar.cpython-39.pyc | Bin 0 -> 53063 bytes .../nltk/__pycache__/help.cpython-39.pyc | Bin 0 -> 1606 bytes .../nltk/__pycache__/internals.cpython-39.pyc | Bin 0 -> 28745 bytes .../nltk/__pycache__/jsontags.cpython-39.pyc | Bin 0 -> 2292 bytes .../__pycache__/lazyimport.cpython-39.pyc | Bin 0 -> 3664 bytes .../__pycache__/probability.cpython-39.pyc | Bin 0 -> 87196 bytes .../nltk/__pycache__/text.cpython-39.pyc | Bin 0 -> 28169 bytes .../nltk/__pycache__/tgrep.cpython-39.pyc | Bin 0 -> 35235 bytes .../nltk/__pycache__/toolbox.cpython-39.pyc | Bin 0 -> 15798 bytes .../nltk/__pycache__/tree.cpython-39.pyc | Bin 0 -> 55772 bytes .../treeprettyprinter.cpython-39.pyc | Bin 0 -> 20632 bytes .../__pycache__/treetransforms.cpython-39.pyc | Bin 0 -> 9391 bytes .../nltk/__pycache__/util.cpython-39.pyc | Bin 0 -> 32449 bytes .../nltk/__pycache__/wsd.cpython-39.pyc | Bin 0 -> 1801 bytes .../Lib/site-packages/nltk/app/__init__.py | 47 + .../app/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1294 bytes .../chartparser_app.cpython-39.pyc | Bin 0 -> 63158 bytes .../chunkparser_app.cpython-39.pyc | Bin 0 -> 33362 bytes .../collocations_app.cpython-39.pyc | Bin 0 -> 14779 bytes .../concordance_app.cpython-39.pyc | Bin 0 -> 22699 bytes .../app/__pycache__/nemo_app.cpython-39.pyc | Bin 0 -> 12245 bytes .../__pycache__/rdparser_app.cpython-39.pyc | Bin 0 -> 25958 bytes .../__pycache__/srparser_app.cpython-39.pyc | Bin 0 -> 21991 bytes .../__pycache__/wordfreq_app.cpython-39.pyc | Bin 0 -> 1444 bytes .../__pycache__/wordnet_app.cpython-39.pyc | Bin 0 -> 30579 bytes .../site-packages/nltk/app/chartparser_app.py | 2569 +++++ .../site-packages/nltk/app/chunkparser_app.py | 1500 +++ .../nltk/app/collocations_app.py | 438 + .../site-packages/nltk/app/concordance_app.py | 709 ++ .../Lib/site-packages/nltk/app/nemo_app.py | 163 + .../site-packages/nltk/app/rdparser_app.py | 1052 ++ .../site-packages/nltk/app/srparser_app.py | 937 ++ .../site-packages/nltk/app/wordfreq_app.py | 36 + .../Lib/site-packages/nltk/app/wordnet_app.py | 997 ++ .../pyvenv3.9/Lib/site-packages/nltk/book.py | 213 + .../Lib/site-packages/nltk/ccg/__init__.py | 34 + .../ccg/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 943 bytes .../nltk/ccg/__pycache__/api.cpython-39.pyc | Bin 0 -> 11889 bytes .../nltk/ccg/__pycache__/chart.cpython-39.pyc | Bin 0 -> 12895 bytes .../ccg/__pycache__/combinator.cpython-39.pyc | Bin 0 -> 9407 bytes .../ccg/__pycache__/lexicon.cpython-39.pyc | Bin 0 -> 7840 bytes .../nltk/ccg/__pycache__/logic.cpython-39.pyc | Bin 0 -> 1471 bytes .../Lib/site-packages/nltk/ccg/api.py | 358 + .../Lib/site-packages/nltk/ccg/chart.py | 480 + .../Lib/site-packages/nltk/ccg/combinator.py | 339 + .../Lib/site-packages/nltk/ccg/lexicon.py | 338 + .../Lib/site-packages/nltk/ccg/logic.py | 60 + .../Lib/site-packages/nltk/chat/__init__.py | 51 + .../chat/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1384 bytes .../chat/__pycache__/eliza.cpython-39.pyc | Bin 0 -> 5849 bytes .../chat/__pycache__/iesha.cpython-39.pyc | Bin 0 -> 3204 bytes .../nltk/chat/__pycache__/rude.cpython-39.pyc | Bin 0 -> 2175 bytes .../chat/__pycache__/suntsu.cpython-39.pyc | Bin 0 -> 5924 bytes .../nltk/chat/__pycache__/util.cpython-39.pyc | Bin 0 -> 3620 bytes .../nltk/chat/__pycache__/zen.cpython-39.pyc | Bin 0 -> 6479 bytes .../Lib/site-packages/nltk/chat/eliza.py | 337 + .../Lib/site-packages/nltk/chat/iesha.py | 160 + .../Lib/site-packages/nltk/chat/rude.py | 125 + .../Lib/site-packages/nltk/chat/suntsu.py | 140 + .../Lib/site-packages/nltk/chat/util.py | 124 + .../Lib/site-packages/nltk/chat/zen.py | 329 + .../Lib/site-packages/nltk/chunk/__init__.py | 197 + .../chunk/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 7278 bytes .../nltk/chunk/__pycache__/api.cpython-39.pyc | Bin 0 -> 1721 bytes .../__pycache__/named_entity.cpython-39.pyc | Bin 0 -> 9329 bytes .../chunk/__pycache__/regexp.cpython-39.pyc | Bin 0 -> 48073 bytes .../chunk/__pycache__/util.cpython-39.pyc | Bin 0 -> 17808 bytes .../Lib/site-packages/nltk/chunk/api.py | 51 + .../site-packages/nltk/chunk/named_entity.py | 352 + .../Lib/site-packages/nltk/chunk/regexp.py | 1470 +++ .../Lib/site-packages/nltk/chunk/util.py | 643 ++ .../site-packages/nltk/classify/__init__.py | 101 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 4663 bytes .../classify/__pycache__/api.cpython-39.pyc | Bin 0 -> 5244 bytes .../__pycache__/decisiontree.cpython-39.pyc | Bin 0 -> 9617 bytes .../__pycache__/maxent.cpython-39.pyc | Bin 0 -> 46862 bytes .../classify/__pycache__/megam.cpython-39.pyc | Bin 0 -> 5167 bytes .../__pycache__/naivebayes.cpython-39.pyc | Bin 0 -> 7936 bytes .../positivenaivebayes.cpython-39.pyc | Bin 0 -> 5287 bytes .../__pycache__/rte_classify.cpython-39.pyc | Bin 0 -> 5591 bytes .../__pycache__/scikitlearn.cpython-39.pyc | Bin 0 -> 5897 bytes .../classify/__pycache__/senna.cpython-39.pyc | Bin 0 -> 5656 bytes .../classify/__pycache__/svm.cpython-39.pyc | Bin 0 -> 668 bytes .../classify/__pycache__/tadm.cpython-39.pyc | Bin 0 -> 3285 bytes .../__pycache__/textcat.cpython-39.pyc | Bin 0 -> 4656 bytes .../classify/__pycache__/util.cpython-39.pyc | Bin 0 -> 10835 bytes .../classify/__pycache__/weka.cpython-39.pyc | Bin 0 -> 10254 bytes .../Lib/site-packages/nltk/classify/api.py | 195 + .../nltk/classify/decisiontree.py | 349 + .../Lib/site-packages/nltk/classify/maxent.py | 1569 +++ .../Lib/site-packages/nltk/classify/megam.py | 184 + .../site-packages/nltk/classify/naivebayes.py | 260 + .../nltk/classify/positivenaivebayes.py | 180 + .../nltk/classify/rte_classify.py | 181 + .../nltk/classify/scikitlearn.py | 143 + .../Lib/site-packages/nltk/classify/senna.py | 177 + .../Lib/site-packages/nltk/classify/svm.py | 17 + .../Lib/site-packages/nltk/classify/tadm.py | 122 + .../site-packages/nltk/classify/textcat.py | 197 + .../Lib/site-packages/nltk/classify/util.py | 346 + .../Lib/site-packages/nltk/classify/weka.py | 377 + .../pyvenv3.9/Lib/site-packages/nltk/cli.py | 55 + .../site-packages/nltk/cluster/__init__.py | 90 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 4293 bytes .../cluster/__pycache__/api.cpython-39.pyc | Bin 0 -> 2413 bytes .../cluster/__pycache__/em.cpython-39.pyc | Bin 0 -> 6786 bytes .../cluster/__pycache__/gaac.cpython-39.pyc | Bin 0 -> 4933 bytes .../cluster/__pycache__/kmeans.cpython-39.pyc | Bin 0 -> 6621 bytes .../cluster/__pycache__/util.cpython-39.pyc | Bin 0 -> 9801 bytes .../Lib/site-packages/nltk/cluster/api.py | 74 + .../Lib/site-packages/nltk/cluster/em.py | 219 + .../Lib/site-packages/nltk/cluster/gaac.py | 170 + .../Lib/site-packages/nltk/cluster/kmeans.py | 231 + .../Lib/site-packages/nltk/cluster/util.py | 299 + .../Lib/site-packages/nltk/collections.py | 661 ++ .../Lib/site-packages/nltk/collocations.py | 412 + .../Lib/site-packages/nltk/compat.py | 43 + .../Lib/site-packages/nltk/corpus/__init__.py | 483 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 9252 bytes .../__pycache__/europarl_raw.cpython-39.pyc | Bin 0 -> 999 bytes .../corpus/__pycache__/util.cpython-39.pyc | Bin 0 -> 4499 bytes .../site-packages/nltk/corpus/europarl_raw.py | 56 + .../nltk/corpus/reader/__init__.py | 184 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 5617 bytes .../reader/__pycache__/aligned.cpython-39.pyc | Bin 0 -> 4349 bytes .../reader/__pycache__/api.cpython-39.pyc | Bin 0 -> 19308 bytes .../reader/__pycache__/bnc.cpython-39.pyc | Bin 0 -> 9349 bytes .../__pycache__/bracket_parse.cpython-39.pyc | Bin 0 -> 9870 bytes .../categorized_sents.cpython-39.pyc | Bin 0 -> 6037 bytes .../reader/__pycache__/chasen.cpython-39.pyc | Bin 0 -> 5260 bytes .../reader/__pycache__/childes.cpython-39.pyc | Bin 0 -> 18772 bytes .../reader/__pycache__/chunked.cpython-39.pyc | Bin 0 -> 9098 bytes .../reader/__pycache__/cmudict.cpython-39.pyc | Bin 0 -> 3727 bytes .../comparative_sents.cpython-39.pyc | Bin 0 -> 10087 bytes .../reader/__pycache__/conll.cpython-39.pyc | Bin 0 -> 17019 bytes .../__pycache__/crubadan.cpython-39.pyc | Bin 0 -> 3976 bytes .../__pycache__/dependency.cpython-39.pyc | Bin 0 -> 4324 bytes .../__pycache__/framenet.cpython-39.pyc | Bin 0 -> 104512 bytes .../reader/__pycache__/ieer.cpython-39.pyc | Bin 0 -> 3867 bytes .../reader/__pycache__/indian.cpython-39.pyc | Bin 0 -> 3726 bytes .../reader/__pycache__/ipipan.cpython-39.pyc | Bin 0 -> 11538 bytes .../reader/__pycache__/knbc.cpython-39.pyc | Bin 0 -> 5954 bytes .../reader/__pycache__/lin.cpython-39.pyc | Bin 0 -> 5924 bytes .../reader/__pycache__/mte.cpython-39.pyc | Bin 0 -> 16449 bytes .../reader/__pycache__/nkjp.cpython-39.pyc | Bin 0 -> 15275 bytes .../reader/__pycache__/nombank.cpython-39.pyc | Bin 0 -> 13862 bytes .../__pycache__/nps_chat.cpython-39.pyc | Bin 0 -> 3954 bytes .../opinion_lexicon.cpython-39.pyc | Bin 0 -> 4363 bytes .../__pycache__/panlex_lite.cpython-39.pyc | Bin 0 -> 5921 bytes .../__pycache__/panlex_swadesh.cpython-39.pyc | Bin 0 -> 3949 bytes .../reader/__pycache__/pl196x.cpython-39.pyc | Bin 0 -> 8873 bytes .../__pycache__/plaintext.cpython-39.pyc | Bin 0 -> 8960 bytes .../__pycache__/ppattach.cpython-39.pyc | Bin 0 -> 3311 bytes .../__pycache__/propbank.cpython-39.pyc | Bin 0 -> 15449 bytes .../__pycache__/pros_cons.cpython-39.pyc | Bin 0 -> 4752 bytes .../reader/__pycache__/reviews.cpython-39.pyc | Bin 0 -> 12007 bytes .../reader/__pycache__/rte.cpython-39.pyc | Bin 0 -> 4863 bytes .../reader/__pycache__/semcor.cpython-39.pyc | Bin 0 -> 9097 bytes .../__pycache__/senseval.cpython-39.pyc | Bin 0 -> 5372 bytes .../__pycache__/sentiwordnet.cpython-39.pyc | Bin 0 -> 5238 bytes .../sinica_treebank.cpython-39.pyc | Bin 0 -> 3046 bytes .../string_category.cpython-39.pyc | Bin 0 -> 1917 bytes .../__pycache__/switchboard.cpython-39.pyc | Bin 0 -> 6058 bytes .../reader/__pycache__/tagged.cpython-39.pyc | Bin 0 -> 11078 bytes .../reader/__pycache__/timit.cpython-39.pyc | Bin 0 -> 16590 bytes .../reader/__pycache__/toolbox.cpython-39.pyc | Bin 0 -> 2267 bytes .../reader/__pycache__/twitter.cpython-39.pyc | Bin 0 -> 4616 bytes .../reader/__pycache__/udhr.cpython-39.pyc | Bin 0 -> 2007 bytes .../reader/__pycache__/util.cpython-39.pyc | Bin 0 -> 23457 bytes .../reader/__pycache__/verbnet.cpython-39.pyc | Bin 0 -> 21437 bytes .../__pycache__/wordlist.cpython-39.pyc | Bin 0 -> 6082 bytes .../reader/__pycache__/wordnet.cpython-39.pyc | Bin 0 -> 67979 bytes .../reader/__pycache__/xmldocs.cpython-39.pyc | Bin 0 -> 10939 bytes .../reader/__pycache__/ycoe.cpython-39.pyc | Bin 0 -> 10555 bytes .../nltk/corpus/reader/aligned.py | 154 + .../site-packages/nltk/corpus/reader/api.py | 515 + .../site-packages/nltk/corpus/reader/bnc.py | 265 + .../nltk/corpus/reader/bracket_parse.py | 239 + .../nltk/corpus/reader/categorized_sents.py | 168 + .../nltk/corpus/reader/chasen.py | 160 + .../nltk/corpus/reader/childes.py | 630 ++ .../nltk/corpus/reader/chunked.py | 273 + .../nltk/corpus/reader/cmudict.py | 88 + .../nltk/corpus/reader/comparative_sents.py | 309 + .../site-packages/nltk/corpus/reader/conll.py | 579 ++ .../nltk/corpus/reader/crubadan.py | 106 + .../nltk/corpus/reader/dependency.py | 117 + .../nltk/corpus/reader/framenet.py | 3432 +++++++ .../site-packages/nltk/corpus/reader/ieer.py | 116 + .../nltk/corpus/reader/indian.py | 93 + .../nltk/corpus/reader/ipipan.py | 356 + .../site-packages/nltk/corpus/reader/knbc.py | 191 + .../site-packages/nltk/corpus/reader/lin.py | 183 + .../site-packages/nltk/corpus/reader/mte.py | 397 + .../site-packages/nltk/corpus/reader/nkjp.py | 487 + .../nltk/corpus/reader/nombank.py | 466 + .../nltk/corpus/reader/nps_chat.py | 90 + .../nltk/corpus/reader/opinion_lexicon.py | 122 + .../nltk/corpus/reader/panlex_lite.py | 174 + .../nltk/corpus/reader/panlex_swadesh.py | 95 + .../nltk/corpus/reader/pl196x.py | 375 + .../nltk/corpus/reader/plaintext.py | 226 + .../nltk/corpus/reader/ppattach.py | 95 + .../nltk/corpus/reader/propbank.py | 520 + .../nltk/corpus/reader/pros_cons.py | 133 + .../nltk/corpus/reader/reviews.py | 329 + .../site-packages/nltk/corpus/reader/rte.py | 146 + .../nltk/corpus/reader/semcor.py | 296 + .../nltk/corpus/reader/senseval.py | 196 + .../nltk/corpus/reader/sentiwordnet.py | 136 + .../nltk/corpus/reader/sinica_treebank.py | 75 + .../nltk/corpus/reader/string_category.py | 56 + .../nltk/corpus/reader/switchboard.py | 125 + .../nltk/corpus/reader/tagged.py | 354 + .../site-packages/nltk/corpus/reader/timit.py | 510 + .../nltk/corpus/reader/toolbox.py | 76 + .../nltk/corpus/reader/twitter.py | 140 + .../site-packages/nltk/corpus/reader/udhr.py | 73 + .../site-packages/nltk/corpus/reader/util.py | 867 ++ .../nltk/corpus/reader/verbnet.py | 625 ++ .../nltk/corpus/reader/wordlist.py | 165 + .../nltk/corpus/reader/wordnet.py | 2288 +++++ .../nltk/corpus/reader/xmldocs.py | 397 + .../site-packages/nltk/corpus/reader/ycoe.py | 256 + .../Lib/site-packages/nltk/corpus/util.py | 154 + .../pyvenv3.9/Lib/site-packages/nltk/data.py | 1441 +++ .../Lib/site-packages/nltk/decorators.py | 251 + .../Lib/site-packages/nltk/downloader.py | 2545 +++++ .../Lib/site-packages/nltk/draw/__init__.py | 27 + .../draw/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 654 bytes .../nltk/draw/__pycache__/cfg.cpython-39.pyc | Bin 0 -> 20596 bytes .../__pycache__/dispersion.cpython-39.pyc | Bin 0 -> 1707 bytes .../draw/__pycache__/table.cpython-39.pyc | Bin 0 -> 38600 bytes .../nltk/draw/__pycache__/tree.cpython-39.pyc | Bin 0 -> 28292 bytes .../nltk/draw/__pycache__/util.cpython-39.pyc | Bin 0 -> 78775 bytes .../Lib/site-packages/nltk/draw/cfg.py | 859 ++ .../Lib/site-packages/nltk/draw/dispersion.py | 65 + .../Lib/site-packages/nltk/draw/table.py | 1176 +++ .../Lib/site-packages/nltk/draw/tree.py | 1129 +++ .../Lib/site-packages/nltk/draw/util.py | 2572 +++++ .../Lib/site-packages/nltk/featstruct.py | 2778 ++++++ .../Lib/site-packages/nltk/grammar.py | 1705 ++++ .../pyvenv3.9/Lib/site-packages/nltk/help.py | 64 + .../site-packages/nltk/inference/__init__.py | 24 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 828 bytes .../inference/__pycache__/api.cpython-39.pyc | Bin 0 -> 19504 bytes .../__pycache__/discourse.cpython-39.pyc | Bin 0 -> 20769 bytes .../inference/__pycache__/mace.cpython-39.pyc | Bin 0 -> 10650 bytes .../__pycache__/nonmonotonic.cpython-39.pyc | Bin 0 -> 16396 bytes .../__pycache__/prover9.cpython-39.pyc | Bin 0 -> 12835 bytes .../__pycache__/resolution.cpython-39.pyc | Bin 0 -> 21261 bytes .../__pycache__/tableau.cpython-39.pyc | Bin 0 -> 18129 bytes .../Lib/site-packages/nltk/inference/api.py | 614 ++ .../site-packages/nltk/inference/discourse.py | 651 ++ .../Lib/site-packages/nltk/inference/mace.py | 383 + .../nltk/inference/nonmonotonic.py | 559 ++ .../site-packages/nltk/inference/prover9.py | 508 + .../nltk/inference/resolution.py | 759 ++ .../site-packages/nltk/inference/tableau.py | 712 ++ .../Lib/site-packages/nltk/internals.py | 1135 +++ .../Lib/site-packages/nltk/jsontags.py | 65 + .../Lib/site-packages/nltk/lazyimport.py | 141 + .../Lib/site-packages/nltk/lm/__init__.py | 235 + .../lm/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 7675 bytes .../nltk/lm/__pycache__/api.cpython-39.pyc | Bin 0 -> 8031 bytes .../lm/__pycache__/counter.cpython-39.pyc | Bin 0 -> 5435 bytes .../nltk/lm/__pycache__/models.cpython-39.pyc | Bin 0 -> 5461 bytes .../__pycache__/preprocessing.cpython-39.pyc | Bin 0 -> 1787 bytes .../lm/__pycache__/smoothing.cpython-39.pyc | Bin 0 -> 5290 bytes .../nltk/lm/__pycache__/util.cpython-39.pyc | Bin 0 -> 483 bytes .../lm/__pycache__/vocabulary.cpython-39.pyc | Bin 0 -> 7855 bytes .../Lib/site-packages/nltk/lm/api.py | 230 + .../Lib/site-packages/nltk/lm/counter.py | 162 + .../Lib/site-packages/nltk/lm/models.py | 141 + .../site-packages/nltk/lm/preprocessing.py | 50 + .../Lib/site-packages/nltk/lm/smoothing.py | 127 + .../Lib/site-packages/nltk/lm/util.py | 19 + .../Lib/site-packages/nltk/lm/vocabulary.py | 217 + .../site-packages/nltk/metrics/__init__.py | 51 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1287 bytes .../__pycache__/agreement.cpython-39.pyc | Bin 0 -> 16505 bytes .../metrics/__pycache__/aline.cpython-39.pyc | Bin 0 -> 12343 bytes .../__pycache__/association.cpython-39.pyc | Bin 0 -> 15595 bytes .../confusionmatrix.cpython-39.pyc | Bin 0 -> 6896 bytes .../__pycache__/distance.cpython-39.pyc | Bin 0 -> 14653 bytes .../metrics/__pycache__/paice.cpython-39.pyc | Bin 0 -> 11278 bytes .../metrics/__pycache__/scores.cpython-39.pyc | Bin 0 -> 7566 bytes .../__pycache__/segmentation.cpython-39.pyc | Bin 0 -> 6473 bytes .../__pycache__/spearman.cpython-39.pyc | Bin 0 -> 2237 bytes .../site-packages/nltk/metrics/agreement.py | 465 + .../Lib/site-packages/nltk/metrics/aline.py | 1353 +++ .../site-packages/nltk/metrics/association.py | 474 + .../nltk/metrics/confusionmatrix.py | 216 + .../site-packages/nltk/metrics/distance.py | 503 + .../Lib/site-packages/nltk/metrics/paice.py | 389 + .../Lib/site-packages/nltk/metrics/scores.py | 228 + .../nltk/metrics/segmentation.py | 222 + .../site-packages/nltk/metrics/spearman.py | 68 + .../Lib/site-packages/nltk/misc/__init__.py | 11 + .../misc/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 377 bytes .../misc/__pycache__/babelfish.cpython-39.pyc | Bin 0 -> 592 bytes .../misc/__pycache__/chomsky.cpython-39.pyc | Bin 0 -> 5084 bytes .../__pycache__/minimalset.cpython-39.pyc | Bin 0 -> 2931 bytes .../nltk/misc/__pycache__/sort.cpython-39.pyc | Bin 0 -> 3391 bytes .../__pycache__/wordfinder.cpython-39.pyc | Bin 0 -> 4063 bytes .../Lib/site-packages/nltk/misc/babelfish.py | 10 + .../Lib/site-packages/nltk/misc/chomsky.py | 134 + .../Lib/site-packages/nltk/misc/minimalset.py | 85 + .../Lib/site-packages/nltk/misc/sort.py | 176 + .../Lib/site-packages/nltk/misc/wordfinder.py | 139 + .../Lib/site-packages/nltk/parse/__init__.py | 102 + .../parse/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3905 bytes .../nltk/parse/__pycache__/api.cpython-39.pyc | Bin 0 -> 2602 bytes .../parse/__pycache__/bllip.cpython-39.pyc | Bin 0 -> 7036 bytes .../parse/__pycache__/chart.cpython-39.pyc | Bin 0 -> 54470 bytes .../parse/__pycache__/corenlp.cpython-39.pyc | Bin 0 -> 23057 bytes .../dependencygraph.cpython-39.pyc | Bin 0 -> 29270 bytes .../__pycache__/earleychart.cpython-39.pyc | Bin 0 -> 16177 bytes .../parse/__pycache__/evaluate.cpython-39.pyc | Bin 0 -> 4011 bytes .../__pycache__/featurechart.cpython-39.pyc | Bin 0 -> 18921 bytes .../parse/__pycache__/generate.cpython-39.pyc | Bin 0 -> 2140 bytes .../parse/__pycache__/malt.cpython-39.pyc | Bin 0 -> 9944 bytes ...nprojectivedependencyparser.cpython-39.pyc | Bin 0 -> 21521 bytes .../parse/__pycache__/pchart.cpython-39.pyc | Bin 0 -> 17316 bytes .../projectivedependencyparser.cpython-39.pyc | Bin 0 -> 17933 bytes .../recursivedescent.cpython-39.pyc | Bin 0 -> 23660 bytes .../__pycache__/shiftreduce.cpython-39.pyc | Bin 0 -> 15392 bytes .../parse/__pycache__/stanford.cpython-39.pyc | Bin 0 -> 17332 bytes .../transitionparser.cpython-39.pyc | Bin 0 -> 21249 bytes .../parse/__pycache__/util.cpython-39.pyc | Bin 0 -> 7264 bytes .../parse/__pycache__/viterbi.cpython-39.pyc | Bin 0 -> 14570 bytes .../Lib/site-packages/nltk/parse/api.py | 72 + .../Lib/site-packages/nltk/parse/bllip.py | 300 + .../Lib/site-packages/nltk/parse/chart.py | 1848 ++++ .../Lib/site-packages/nltk/parse/corenlp.py | 744 ++ .../nltk/parse/dependencygraph.py | 792 ++ .../site-packages/nltk/parse/earleychart.py | 552 ++ .../Lib/site-packages/nltk/parse/evaluate.py | 129 + .../site-packages/nltk/parse/featurechart.py | 674 ++ .../Lib/site-packages/nltk/parse/generate.py | 88 + .../Lib/site-packages/nltk/parse/malt.py | 394 + .../parse/nonprojectivedependencyparser.py | 771 ++ .../Lib/site-packages/nltk/parse/pchart.py | 579 ++ .../nltk/parse/projectivedependencyparser.py | 716 ++ .../nltk/parse/recursivedescent.py | 684 ++ .../site-packages/nltk/parse/shiftreduce.py | 479 + .../Lib/site-packages/nltk/parse/stanford.py | 470 + .../nltk/parse/transitionparser.py | 788 ++ .../Lib/site-packages/nltk/parse/util.py | 229 + .../Lib/site-packages/nltk/parse/viterbi.py | 412 + .../Lib/site-packages/nltk/probability.py | 2590 +++++ .../Lib/site-packages/nltk/sem/__init__.py | 75 + .../sem/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2336 bytes .../nltk/sem/__pycache__/boxer.cpython-39.pyc | Bin 0 -> 46535 bytes .../sem/__pycache__/chat80.cpython-39.pyc | Bin 0 -> 21194 bytes .../__pycache__/cooper_storage.cpython-39.pyc | Bin 0 -> 3798 bytes .../nltk/sem/__pycache__/drt.cpython-39.pyc | Bin 0 -> 45673 bytes .../__pycache__/drt_glue_demo.cpython-39.pyc | Bin 0 -> 13153 bytes .../sem/__pycache__/evaluate.cpython-39.pyc | Bin 0 -> 21692 bytes .../nltk/sem/__pycache__/glue.cpython-39.pyc | Bin 0 -> 19656 bytes .../nltk/sem/__pycache__/hole.cpython-39.pyc | Bin 0 -> 11038 bytes .../nltk/sem/__pycache__/lfg.cpython-39.pyc | Bin 0 -> 5954 bytes .../__pycache__/linearlogic.cpython-39.pyc | Bin 0 -> 17195 bytes .../nltk/sem/__pycache__/logic.cpython-39.pyc | Bin 0 -> 65247 bytes .../sem/__pycache__/relextract.cpython-39.pyc | Bin 0 -> 13337 bytes .../sem/__pycache__/skolemize.cpython-39.pyc | Bin 0 -> 2339 bytes .../nltk/sem/__pycache__/util.cpython-39.pyc | Bin 0 -> 7979 bytes .../Lib/site-packages/nltk/sem/boxer.py | 1602 ++++ .../Lib/site-packages/nltk/sem/chat80.py | 857 ++ .../site-packages/nltk/sem/cooper_storage.py | 124 + .../Lib/site-packages/nltk/sem/drt.py | 1460 +++ .../site-packages/nltk/sem/drt_glue_demo.py | 553 ++ .../Lib/site-packages/nltk/sem/evaluate.py | 821 ++ .../Lib/site-packages/nltk/sem/glue.py | 835 ++ .../Lib/site-packages/nltk/sem/hole.py | 395 + .../Lib/site-packages/nltk/sem/lfg.py | 261 + .../Lib/site-packages/nltk/sem/linearlogic.py | 482 + .../Lib/site-packages/nltk/sem/logic.py | 2055 ++++ .../Lib/site-packages/nltk/sem/relextract.py | 540 ++ .../Lib/site-packages/nltk/sem/skolemize.py | 148 + .../Lib/site-packages/nltk/sem/util.py | 309 + .../site-packages/nltk/sentiment/__init__.py | 13 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 352 bytes .../sentiment_analyzer.cpython-39.pyc | Bin 0 -> 9775 bytes .../sentiment/__pycache__/util.cpython-39.pyc | Bin 0 -> 22178 bytes .../__pycache__/vader.cpython-39.pyc | Bin 0 -> 13020 bytes .../nltk/sentiment/sentiment_analyzer.py | 254 + .../Lib/site-packages/nltk/sentiment/util.py | 885 ++ .../Lib/site-packages/nltk/sentiment/vader.py | 628 ++ .../Lib/site-packages/nltk/stem/__init__.py | 34 + .../stem/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1260 bytes .../nltk/stem/__pycache__/api.cpython-39.pyc | Bin 0 -> 793 bytes .../stem/__pycache__/arlstem.cpython-39.pyc | Bin 0 -> 8183 bytes .../stem/__pycache__/arlstem2.cpython-39.pyc | Bin 0 -> 9834 bytes .../stem/__pycache__/cistem.cpython-39.pyc | Bin 0 -> 6303 bytes .../nltk/stem/__pycache__/isri.cpython-39.pyc | Bin 0 -> 9227 bytes .../stem/__pycache__/lancaster.cpython-39.pyc | Bin 0 -> 6358 bytes .../stem/__pycache__/porter.cpython-39.pyc | Bin 0 -> 21589 bytes .../stem/__pycache__/regexp.cpython-39.pyc | Bin 0 -> 1703 bytes .../nltk/stem/__pycache__/rslp.cpython-39.pyc | Bin 0 -> 3011 bytes .../stem/__pycache__/snowball.cpython-39.pyc | Bin 0 -> 97824 bytes .../nltk/stem/__pycache__/util.cpython-39.pyc | Bin 0 -> 655 bytes .../stem/__pycache__/wordnet.cpython-39.pyc | Bin 0 -> 1825 bytes .../Lib/site-packages/nltk/stem/api.py | 27 + .../Lib/site-packages/nltk/stem/arlstem.py | 361 + .../Lib/site-packages/nltk/stem/arlstem2.py | 456 + .../Lib/site-packages/nltk/stem/cistem.py | 209 + .../Lib/site-packages/nltk/stem/isri.py | 395 + .../Lib/site-packages/nltk/stem/lancaster.py | 343 + .../Lib/site-packages/nltk/stem/porter.py | 712 ++ .../Lib/site-packages/nltk/stem/regexp.py | 56 + .../Lib/site-packages/nltk/stem/rslp.py | 137 + .../Lib/site-packages/nltk/stem/snowball.py | 5938 ++++++++++++ .../Lib/site-packages/nltk/stem/util.py | 24 + .../Lib/site-packages/nltk/stem/wordnet.py | 49 + .../Lib/site-packages/nltk/tag/__init__.py | 184 + .../tag/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 6970 bytes .../nltk/tag/__pycache__/api.cpython-39.pyc | Bin 0 -> 3457 bytes .../nltk/tag/__pycache__/brill.cpython-39.pyc | Bin 0 -> 14156 bytes .../__pycache__/brill_trainer.cpython-39.pyc | Bin 0 -> 18734 bytes .../nltk/tag/__pycache__/crf.cpython-39.pyc | Bin 0 -> 7507 bytes .../nltk/tag/__pycache__/hmm.cpython-39.pyc | Bin 0 -> 40937 bytes .../tag/__pycache__/hunpos.cpython-39.pyc | Bin 0 -> 4404 bytes .../tag/__pycache__/mapping.cpython-39.pyc | Bin 0 -> 3226 bytes .../tag/__pycache__/perceptron.cpython-39.pyc | Bin 0 -> 11591 bytes .../nltk/tag/__pycache__/senna.cpython-39.pyc | Bin 0 -> 5292 bytes .../tag/__pycache__/sequential.cpython-39.pyc | Bin 0 -> 26676 bytes .../tag/__pycache__/stanford.cpython-39.pyc | Bin 0 -> 7291 bytes .../nltk/tag/__pycache__/tnt.cpython-39.pyc | Bin 0 -> 12944 bytes .../nltk/tag/__pycache__/util.cpython-39.pyc | Bin 0 -> 2408 bytes .../Lib/site-packages/nltk/tag/api.py | 83 + .../Lib/site-packages/nltk/tag/brill.py | 449 + .../site-packages/nltk/tag/brill_trainer.py | 630 ++ .../Lib/site-packages/nltk/tag/crf.py | 204 + .../Lib/site-packages/nltk/tag/hmm.py | 1329 +++ .../Lib/site-packages/nltk/tag/hunpos.py | 138 + .../Lib/site-packages/nltk/tag/mapping.py | 136 + .../Lib/site-packages/nltk/tag/perceptron.py | 371 + .../Lib/site-packages/nltk/tag/senna.py | 133 + .../Lib/site-packages/nltk/tag/sequential.py | 755 ++ .../Lib/site-packages/nltk/tag/stanford.py | 236 + .../Lib/site-packages/nltk/tag/tnt.py | 579 ++ .../Lib/site-packages/nltk/tag/util.py | 72 + .../Lib/site-packages/nltk/tbl/__init__.py | 31 + .../tbl/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 513 bytes .../nltk/tbl/__pycache__/api.cpython-39.pyc | Bin 0 -> 144 bytes .../nltk/tbl/__pycache__/demo.cpython-39.pyc | Bin 0 -> 12533 bytes .../__pycache__/erroranalysis.cpython-39.pyc | Bin 0 -> 1352 bytes .../tbl/__pycache__/feature.cpython-39.pyc | Bin 0 -> 9783 bytes .../nltk/tbl/__pycache__/rule.cpython-39.pyc | Bin 0 -> 10439 bytes .../tbl/__pycache__/template.cpython-39.pyc | Bin 0 -> 12440 bytes .../Lib/site-packages/nltk/tbl/api.py | 0 .../Lib/site-packages/nltk/tbl/demo.py | 418 + .../site-packages/nltk/tbl/erroranalysis.py | 38 + .../Lib/site-packages/nltk/tbl/feature.py | 264 + .../Lib/site-packages/nltk/tbl/rule.py | 322 + .../Lib/site-packages/nltk/tbl/template.py | 319 + .../Lib/site-packages/nltk/test/__init__.py | 18 + .../test/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 429 bytes .../nltk/test/__pycache__/all.cpython-39.pyc | Bin 0 -> 1066 bytes .../__pycache__/childes_fixt.cpython-39.pyc | Bin 0 -> 574 bytes .../__pycache__/classify_fixt.cpython-39.pyc | Bin 0 -> 310 bytes .../test/__pycache__/conftest.cpython-39.pyc | Bin 0 -> 986 bytes .../__pycache__/discourse_fixt.cpython-39.pyc | Bin 0 -> 519 bytes .../__pycache__/gensim_fixt.cpython-39.pyc | Bin 0 -> 309 bytes .../gluesemantics_malt_fixt.cpython-39.pyc | Bin 0 -> 510 bytes .../__pycache__/inference_fixt.cpython-39.pyc | Bin 0 -> 499 bytes .../nonmonotonic_fixt.cpython-39.pyc | Bin 0 -> 530 bytes .../portuguese_en_fixt.cpython-39.pyc | Bin 0 -> 369 bytes .../probability_fixt.cpython-39.pyc | Bin 0 -> 313 bytes .../Lib/site-packages/nltk/test/all.py | 25 + .../Lib/site-packages/nltk/test/bleu.doctest | 29 + .../Lib/site-packages/nltk/test/bnc.doctest | 60 + .../Lib/site-packages/nltk/test/ccg.doctest | 376 + .../nltk/test/ccg_semantics.doctest | 552 ++ .../site-packages/nltk/test/chat80.doctest | 232 + .../site-packages/nltk/test/childes.doctest | 190 + .../site-packages/nltk/test/childes_fixt.py | 13 + .../Lib/site-packages/nltk/test/chunk.doctest | 372 + .../site-packages/nltk/test/classify.doctest | 202 + .../site-packages/nltk/test/classify_fixt.py | 5 + .../nltk/test/collections.doctest | 31 + .../nltk/test/collocations.doctest | 281 + .../nltk/test/concordance.doctest | 75 + .../Lib/site-packages/nltk/test/conftest.py | 33 + .../site-packages/nltk/test/corpus.doctest | 2196 +++++ .../site-packages/nltk/test/crubadan.doctest | 65 + .../Lib/site-packages/nltk/test/data.doctest | 377 + .../nltk/test/dependency.doctest | 241 + .../site-packages/nltk/test/discourse.doctest | 552 ++ .../site-packages/nltk/test/discourse_fixt.py | 12 + .../Lib/site-packages/nltk/test/drt.doctest | 515 + .../site-packages/nltk/test/featgram.doctest | 606 ++ .../nltk/test/featstruct.doctest | 1228 +++ .../site-packages/nltk/test/framenet.doctest | 288 + .../site-packages/nltk/test/generate.doctest | 66 + .../site-packages/nltk/test/gensim.doctest | 144 + .../site-packages/nltk/test/gensim_fixt.py | 4 + .../nltk/test/gluesemantics.doctest | 384 + .../nltk/test/gluesemantics_malt.doctest | 69 + .../nltk/test/gluesemantics_malt_fixt.py | 9 + .../site-packages/nltk/test/grammar.doctest | 48 + .../nltk/test/grammartestsuites.doctest | 109 + .../Lib/site-packages/nltk/test/index.doctest | 100 + .../site-packages/nltk/test/inference.doctest | 536 ++ .../site-packages/nltk/test/inference_fixt.py | 10 + .../site-packages/nltk/test/internals.doctest | 160 + .../site-packages/nltk/test/japanese.doctest | 48 + .../Lib/site-packages/nltk/test/lm.doctest | 134 + .../Lib/site-packages/nltk/test/logic.doctest | 1096 +++ .../site-packages/nltk/test/meteor.doctest | 54 + .../site-packages/nltk/test/metrics.doctest | 300 + .../Lib/site-packages/nltk/test/misc.doctest | 118 + .../nltk/test/nonmonotonic.doctest | 288 + .../nltk/test/nonmonotonic_fixt.py | 12 + .../Lib/site-packages/nltk/test/paice.doctest | 35 + .../Lib/site-packages/nltk/test/parse.doctest | 897 ++ .../nltk/test/portuguese_en.doctest | 567 ++ .../nltk/test/portuguese_en_fixt.py | 4 + .../nltk/test/probability.doctest | 305 + .../nltk/test/probability_fixt.py | 8 + .../site-packages/nltk/test/propbank.doctest | 176 + .../nltk/test/relextract.doctest | 263 + .../nltk/test/resolution.doctest | 220 + .../site-packages/nltk/test/semantics.doctest | 667 ++ .../site-packages/nltk/test/sentiment.doctest | 236 + .../nltk/test/sentiwordnet.doctest | 41 + .../site-packages/nltk/test/simple.doctest | 83 + .../Lib/site-packages/nltk/test/stem.doctest | 105 + .../Lib/site-packages/nltk/test/tag.doctest | 44 + .../site-packages/nltk/test/tokenize.doctest | 341 + .../site-packages/nltk/test/toolbox.doctest | 306 + .../site-packages/nltk/test/translate.doctest | 240 + .../Lib/site-packages/nltk/test/tree.doctest | 1157 +++ .../nltk/test/treeprettyprinter.doctest | 126 + .../nltk/test/treetransforms.doctest | 155 + .../site-packages/nltk/test/unit/__init__.py | 0 .../unit/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 155 bytes .../__pycache__/test_aline.cpython-39.pyc | Bin 0 -> 1093 bytes .../__pycache__/test_brill.cpython-39.pyc | Bin 0 -> 1280 bytes .../test_cfd_mutation.cpython-39.pyc | Bin 0 -> 1414 bytes .../test_cfg2chomsky.cpython-39.pyc | Bin 0 -> 1601 bytes .../__pycache__/test_chunk.cpython-39.pyc | Bin 0 -> 1911 bytes .../__pycache__/test_classify.cpython-39.pyc | Bin 0 -> 1460 bytes .../test_collocations.cpython-39.pyc | Bin 0 -> 2577 bytes .../test_concordance.cpython-39.pyc | Bin 0 -> 5119 bytes .../__pycache__/test_corenlp.cpython-39.pyc | Bin 0 -> 11135 bytes .../__pycache__/test_corpora.cpython-39.pyc | Bin 0 -> 7257 bytes .../test_corpus_views.cpython-39.pyc | Bin 0 -> 1620 bytes .../unit/__pycache__/test_data.cpython-39.pyc | Bin 0 -> 733 bytes .../test_disagreement.cpython-39.pyc | Bin 0 -> 2631 bytes .../__pycache__/test_distance.cpython-39.pyc | Bin 0 -> 2050 bytes .../__pycache__/test_freqdist.cpython-39.pyc | Bin 0 -> 433 bytes .../unit/__pycache__/test_hmm.cpython-39.pyc | Bin 0 -> 2080 bytes .../test_json2csv_corpus.cpython-39.pyc | Bin 0 -> 5207 bytes .../test_json_serialization.cpython-39.pyc | Bin 0 -> 3400 bytes .../__pycache__/test_metrics.cpython-39.pyc | Bin 0 -> 1687 bytes .../test_naivebayes.cpython-39.pyc | Bin 0 -> 901 bytes .../__pycache__/test_nombank.cpython-39.pyc | Bin 0 -> 1333 bytes .../__pycache__/test_pl196x.cpython-39.pyc | Bin 0 -> 786 bytes .../__pycache__/test_pos_tag.cpython-39.pyc | Bin 0 -> 2416 bytes .../__pycache__/test_ribes.cpython-39.pyc | Bin 0 -> 2327 bytes .../test_rte_classify.cpython-39.pyc | Bin 0 -> 3136 bytes ...kable_unicode_stream_reader.cpython-39.pyc | Bin 0 -> 2002 bytes .../__pycache__/test_senna.cpython-39.pyc | Bin 0 -> 3262 bytes .../unit/__pycache__/test_stem.cpython-39.pyc | Bin 0 -> 5603 bytes .../unit/__pycache__/test_tag.cpython-39.pyc | Bin 0 -> 715 bytes .../__pycache__/test_tgrep.cpython-39.pyc | Bin 0 -> 20710 bytes .../__pycache__/test_tokenize.cpython-39.pyc | Bin 0 -> 16718 bytes .../test_twitter_auth.cpython-39.pyc | Bin 0 -> 2327 bytes .../unit/__pycache__/test_util.cpython-39.pyc | Bin 0 -> 1555 bytes .../__pycache__/test_wordnet.cpython-39.pyc | Bin 0 -> 7376 bytes .../nltk/test/unit/lm/__init__.py | 0 .../lm/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 158 bytes .../__pycache__/test_counter.cpython-39.pyc | Bin 0 -> 5340 bytes .../lm/__pycache__/test_models.cpython-39.pyc | Bin 0 -> 9915 bytes .../test_preprocessing.cpython-39.pyc | Bin 0 -> 1080 bytes .../test_vocabulary.cpython-39.pyc | Bin 0 -> 6862 bytes .../nltk/test/unit/lm/test_counter.py | 116 + .../nltk/test/unit/lm/test_models.py | 610 ++ .../nltk/test/unit/lm/test_preprocessing.py | 30 + .../nltk/test/unit/lm/test_vocabulary.py | 156 + .../nltk/test/unit/test_aline.py | 48 + .../nltk/test/unit/test_brill.py | 34 + .../nltk/test/unit/test_cfd_mutation.py | 39 + .../nltk/test/unit/test_cfg2chomsky.py | 49 + .../nltk/test/unit/test_chunk.py | 85 + .../nltk/test/unit/test_classify.py | 49 + .../nltk/test/unit/test_collocations.py | 120 + .../nltk/test/unit/test_concordance.py | 98 + .../nltk/test/unit/test_corenlp.py | 1436 +++ .../nltk/test/unit/test_corpora.py | 264 + .../nltk/test/unit/test_corpus_views.py | 48 + .../site-packages/nltk/test/unit/test_data.py | 15 + .../nltk/test/unit/test_disagreement.py | 144 + .../nltk/test/unit/test_distance.py | 123 + .../nltk/test/unit/test_freqdist.py | 7 + .../site-packages/nltk/test/unit/test_hmm.py | 82 + .../nltk/test/unit/test_json2csv_corpus.py | 210 + .../nltk/test/unit/test_json_serialization.py | 95 + .../nltk/test/unit/test_metrics.py | 66 + .../nltk/test/unit/test_naivebayes.py | 21 + .../nltk/test/unit/test_nombank.py | 27 + .../nltk/test/unit/test_pl196x.py | 13 + .../nltk/test/unit/test_pos_tag.py | 83 + .../nltk/test/unit/test_ribes.py | 246 + .../nltk/test/unit/test_rte_classify.py | 94 + .../test_seekable_unicode_stream_reader.py | 86 + .../nltk/test/unit/test_senna.py | 112 + .../site-packages/nltk/test/unit/test_stem.py | 158 + .../site-packages/nltk/test/unit/test_tag.py | 23 + .../nltk/test/unit/test_tgrep.py | 780 ++ .../nltk/test/unit/test_tokenize.py | 811 ++ .../nltk/test/unit/test_twitter_auth.py | 77 + .../site-packages/nltk/test/unit/test_util.py | 82 + .../nltk/test/unit/test_wordnet.py | 240 + .../nltk/test/unit/translate/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 165 bytes .../__pycache__/test_bleu.cpython-39.pyc | Bin 0 -> 7501 bytes .../__pycache__/test_gdfa.cpython-39.pyc | Bin 0 -> 3120 bytes .../__pycache__/test_ibm1.cpython-39.pyc | Bin 0 -> 2387 bytes .../__pycache__/test_ibm2.cpython-39.pyc | Bin 0 -> 3140 bytes .../__pycache__/test_ibm3.cpython-39.pyc | Bin 0 -> 3569 bytes .../__pycache__/test_ibm4.cpython-39.pyc | Bin 0 -> 3880 bytes .../__pycache__/test_ibm5.cpython-39.pyc | Bin 0 -> 4966 bytes .../__pycache__/test_ibm_model.cpython-39.pyc | Bin 0 -> 9058 bytes .../__pycache__/test_meteor.cpython-39.pyc | Bin 0 -> 1391 bytes .../__pycache__/test_nist.cpython-39.pyc | Bin 0 -> 1533 bytes .../test_stack_decoder.cpython-39.pyc | Bin 0 -> 8783 bytes .../nltk/test/unit/translate/test_bleu.py | 271 + .../nltk/test/unit/translate/test_gdfa.py | 154 + .../nltk/test/unit/translate/test_ibm1.py | 73 + .../nltk/test/unit/translate/test_ibm2.py | 86 + .../nltk/test/unit/translate/test_ibm3.py | 105 + .../nltk/test/unit/translate/test_ibm4.py | 120 + .../nltk/test/unit/translate/test_ibm5.py | 160 + .../test/unit/translate/test_ibm_model.py | 269 + .../nltk/test/unit/translate/test_meteor.py | 20 + .../nltk/test/unit/translate/test_nist.py | 36 + .../test/unit/translate/test_stack_decoder.py | 294 + .../Lib/site-packages/nltk/test/util.doctest | 47 + .../site-packages/nltk/test/wordnet.doctest | 766 ++ .../nltk/test/wordnet_lch.doctest | 53 + .../Lib/site-packages/nltk/test/wsd.doctest | 68 + .../pyvenv3.9/Lib/site-packages/nltk/text.py | 778 ++ .../pyvenv3.9/Lib/site-packages/nltk/tgrep.py | 1039 ++ .../site-packages/nltk/tokenize/__init__.py | 132 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 5148 bytes .../tokenize/__pycache__/api.cpython-39.pyc | Bin 0 -> 2841 bytes .../__pycache__/casual.cpython-39.pyc | Bin 0 -> 10462 bytes .../__pycache__/destructive.cpython-39.pyc | Bin 0 -> 3104 bytes .../legality_principle.cpython-39.pyc | Bin 0 -> 6094 bytes .../tokenize/__pycache__/mwe.cpython-39.pyc | Bin 0 -> 3692 bytes .../tokenize/__pycache__/nist.cpython-39.pyc | Bin 0 -> 4895 bytes .../tokenize/__pycache__/punkt.cpython-39.pyc | Bin 0 -> 39334 bytes .../__pycache__/regexp.cpython-39.pyc | Bin 0 -> 8002 bytes .../tokenize/__pycache__/repp.cpython-39.pyc | Bin 0 -> 7928 bytes .../tokenize/__pycache__/sexpr.cpython-39.pyc | Bin 0 -> 4936 bytes .../__pycache__/simple.cpython-39.pyc | Bin 0 -> 5416 bytes .../sonority_sequencing.cpython-39.pyc | Bin 0 -> 5659 bytes .../__pycache__/stanford.cpython-39.pyc | Bin 0 -> 3346 bytes .../stanford_segmenter.cpython-39.pyc | Bin 0 -> 6433 bytes .../__pycache__/texttiling.cpython-39.pyc | Bin 0 -> 13614 bytes .../__pycache__/toktok.cpython-39.pyc | Bin 0 -> 4208 bytes .../__pycache__/treebank.cpython-39.pyc | Bin 0 -> 11382 bytes .../tokenize/__pycache__/util.cpython-39.pyc | Bin 0 -> 8235 bytes .../Lib/site-packages/nltk/tokenize/api.py | 80 + .../Lib/site-packages/nltk/tokenize/casual.py | 431 + .../nltk/tokenize/destructive.py | 148 + .../nltk/tokenize/legality_principle.py | 146 + .../Lib/site-packages/nltk/tokenize/mwe.py | 124 + .../Lib/site-packages/nltk/tokenize/nist.py | 179 + .../Lib/site-packages/nltk/tokenize/punkt.py | 1665 ++++ .../Lib/site-packages/nltk/tokenize/regexp.py | 220 + .../Lib/site-packages/nltk/tokenize/repp.py | 149 + .../Lib/site-packages/nltk/tokenize/sexpr.py | 140 + .../Lib/site-packages/nltk/tokenize/simple.py | 137 + .../nltk/tokenize/sonority_sequencing.py | 191 + .../site-packages/nltk/tokenize/stanford.py | 115 + .../nltk/tokenize/stanford_segmenter.py | 292 + .../site-packages/nltk/tokenize/texttiling.py | 476 + .../Lib/site-packages/nltk/tokenize/toktok.py | 179 + .../site-packages/nltk/tokenize/treebank.py | 371 + .../Lib/site-packages/nltk/tokenize/util.py | 295 + .../Lib/site-packages/nltk/toolbox.py | 524 + .../site-packages/nltk/translate/__init__.py | 32 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1423 bytes .../translate/__pycache__/api.cpython-39.pyc | Bin 0 -> 12920 bytes .../__pycache__/bleu_score.cpython-39.pyc | Bin 0 -> 25198 bytes .../__pycache__/chrf_score.cpython-39.pyc | Bin 0 -> 7862 bytes .../__pycache__/gale_church.cpython-39.pyc | Bin 0 -> 7881 bytes .../translate/__pycache__/gdfa.cpython-39.pyc | Bin 0 -> 5124 bytes .../__pycache__/gleu_score.cpython-39.pyc | Bin 0 -> 7610 bytes .../translate/__pycache__/ibm1.cpython-39.pyc | Bin 0 -> 8296 bytes .../translate/__pycache__/ibm2.cpython-39.pyc | Bin 0 -> 11285 bytes .../translate/__pycache__/ibm3.cpython-39.pyc | Bin 0 -> 12751 bytes .../translate/__pycache__/ibm4.cpython-39.pyc | Bin 0 -> 16926 bytes .../translate/__pycache__/ibm5.cpython-39.pyc | Bin 0 -> 22484 bytes .../__pycache__/ibm_model.cpython-39.pyc | Bin 0 -> 16319 bytes .../__pycache__/meteor_score.cpython-39.pyc | Bin 0 -> 15143 bytes .../__pycache__/metrics.cpython-39.pyc | Bin 0 -> 1252 bytes .../__pycache__/nist_score.cpython-39.pyc | Bin 0 -> 5578 bytes .../__pycache__/phrase_based.cpython-39.pyc | Bin 0 -> 6216 bytes .../__pycache__/ribes_score.cpython-39.pyc | Bin 0 -> 10859 bytes .../__pycache__/stack_decoder.cpython-39.pyc | Bin 0 -> 17245 bytes .../Lib/site-packages/nltk/translate/api.py | 334 + .../nltk/translate/bleu_score.py | 644 ++ .../nltk/translate/chrf_score.py | 222 + .../nltk/translate/gale_church.py | 263 + .../Lib/site-packages/nltk/translate/gdfa.py | 138 + .../nltk/translate/gleu_score.py | 190 + .../Lib/site-packages/nltk/translate/ibm1.py | 248 + .../Lib/site-packages/nltk/translate/ibm2.py | 315 + .../Lib/site-packages/nltk/translate/ibm3.py | 342 + .../Lib/site-packages/nltk/translate/ibm4.py | 483 + .../Lib/site-packages/nltk/translate/ibm5.py | 655 ++ .../site-packages/nltk/translate/ibm_model.py | 549 ++ .../nltk/translate/meteor_score.py | 409 + .../site-packages/nltk/translate/metrics.py | 41 + .../nltk/translate/nist_score.py | 195 + .../nltk/translate/phrase_based.py | 193 + .../nltk/translate/ribes_score.py | 330 + .../nltk/translate/stack_decoder.py | 515 + .../pyvenv3.9/Lib/site-packages/nltk/tree.py | 1808 ++++ .../site-packages/nltk/treeprettyprinter.py | 628 ++ .../Lib/site-packages/nltk/treetransforms.py | 338 + .../site-packages/nltk/twitter/__init__.py | 35 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 759 bytes .../twitter/__pycache__/api.cpython-39.pyc | Bin 0 -> 4244 bytes .../twitter/__pycache__/common.cpython-39.pyc | Bin 0 -> 7895 bytes .../__pycache__/twitter_demo.cpython-39.pyc | Bin 0 -> 7831 bytes .../__pycache__/twitterclient.cpython-39.pyc | Bin 0 -> 16228 bytes .../twitter/__pycache__/util.cpython-39.pyc | Bin 0 -> 4229 bytes .../Lib/site-packages/nltk/twitter/api.py | 145 + .../Lib/site-packages/nltk/twitter/common.py | 270 + .../nltk/twitter/twitter_demo.py | 306 + .../nltk/twitter/twitterclient.py | 556 ++ .../Lib/site-packages/nltk/twitter/util.py | 150 + .../pyvenv3.9/Lib/site-packages/nltk/util.py | 1219 +++ .../pyvenv3.9/Lib/site-packages/nltk/wsd.py | 51 + .../pip-21.1.3.dist-info/INSTALLER | 1 + .../pip-21.1.3.dist-info/LICENSE.txt | 20 + .../pip-21.1.3.dist-info/METADATA | 91 + .../site-packages/pip-21.1.3.dist-info/RECORD | 797 ++ .../pip-21.1.3.dist-info/REQUESTED | 0 .../site-packages/pip-21.1.3.dist-info/WHEEL | 5 + .../pip-21.1.3.dist-info/entry_points.txt | 5 + .../pip-21.1.3.dist-info/top_level.txt | 1 + .../Lib/site-packages/pip/__init__.py | 14 + .../Lib/site-packages/pip/__main__.py | 31 + .../pip/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 559 bytes .../pip/__pycache__/__main__.cpython-39.pyc | Bin 0 -> 556 bytes .../site-packages/pip/_internal/__init__.py | 15 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 608 bytes .../__pycache__/build_env.cpython-39.pyc | Bin 0 -> 8921 bytes .../__pycache__/cache.cpython-39.pyc | Bin 0 -> 7811 bytes .../__pycache__/configuration.cpython-39.pyc | Bin 0 -> 10663 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 15612 bytes .../_internal/__pycache__/main.cpython-39.pyc | Bin 0 -> 545 bytes .../__pycache__/pyproject.cpython-39.pyc | Bin 0 -> 3423 bytes .../self_outdated_check.cpython-39.pyc | Bin 0 -> 4308 bytes .../__pycache__/wheel_builder.cpython-39.pyc | Bin 0 -> 8246 bytes .../site-packages/pip/_internal/build_env.py | 286 + .../Lib/site-packages/pip/_internal/cache.py | 287 + .../pip/_internal/cli/__init__.py | 4 + .../cli/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 241 bytes .../__pycache__/autocompletion.cpython-39.pyc | Bin 0 -> 4939 bytes .../__pycache__/base_command.cpython-39.pyc | Bin 0 -> 5762 bytes .../cli/__pycache__/cmdoptions.cpython-39.pyc | Bin 0 -> 20996 bytes .../command_context.cpython-39.pyc | Bin 0 -> 1190 bytes .../cli/__pycache__/main.cpython-39.pyc | Bin 0 -> 1290 bytes .../__pycache__/main_parser.cpython-39.pyc | Bin 0 -> 2071 bytes .../cli/__pycache__/parser.cpython-39.pyc | Bin 0 -> 9335 bytes .../__pycache__/progress_bars.cpython-39.pyc | Bin 0 -> 7407 bytes .../__pycache__/req_command.cpython-39.pyc | Bin 0 -> 11250 bytes .../cli/__pycache__/spinners.cpython-39.pyc | Bin 0 -> 4578 bytes .../__pycache__/status_codes.cpython-39.pyc | Bin 0 -> 320 bytes .../pip/_internal/cli/autocompletion.py | 162 + .../pip/_internal/cli/base_command.py | 221 + .../pip/_internal/cli/cmdoptions.py | 1024 ++ .../pip/_internal/cli/command_context.py | 30 + .../site-packages/pip/_internal/cli/main.py | 71 + .../pip/_internal/cli/main_parser.py | 89 + .../site-packages/pip/_internal/cli/parser.py | 305 + .../pip/_internal/cli/progress_bars.py | 261 + .../pip/_internal/cli/req_command.py | 462 + .../pip/_internal/cli/spinners.py | 172 + .../pip/_internal/cli/status_codes.py | 6 + .../pip/_internal/commands/__init__.py | 110 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2834 bytes .../commands/__pycache__/cache.cpython-39.pyc | Bin 0 -> 5716 bytes .../commands/__pycache__/check.cpython-39.pyc | Bin 0 -> 1482 bytes .../__pycache__/completion.cpython-39.pyc | Bin 0 -> 3038 bytes .../__pycache__/configuration.cpython-39.pyc | Bin 0 -> 8019 bytes .../commands/__pycache__/debug.cpython-39.pyc | Bin 0 -> 6403 bytes .../__pycache__/download.cpython-39.pyc | Bin 0 -> 3889 bytes .../__pycache__/freeze.cpython-39.pyc | Bin 0 -> 2887 bytes .../commands/__pycache__/hash.cpython-39.pyc | Bin 0 -> 1999 bytes .../commands/__pycache__/help.cpython-39.pyc | Bin 0 -> 1218 bytes .../__pycache__/install.cpython-39.pyc | Bin 0 -> 16665 bytes .../commands/__pycache__/list.cpython-39.pyc | Bin 0 -> 8776 bytes .../__pycache__/search.cpython-39.pyc | Bin 0 -> 4875 bytes .../commands/__pycache__/show.cpython-39.pyc | Bin 0 -> 6274 bytes .../__pycache__/uninstall.cpython-39.pyc | Bin 0 -> 2823 bytes .../commands/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 4762 bytes .../pip/_internal/commands/cache.py | 228 + .../pip/_internal/commands/check.py | 48 + .../pip/_internal/commands/completion.py | 93 + .../pip/_internal/commands/configuration.py | 280 + .../pip/_internal/commands/debug.py | 215 + .../pip/_internal/commands/download.py | 141 + .../pip/_internal/commands/freeze.py | 104 + .../pip/_internal/commands/hash.py | 58 + .../pip/_internal/commands/help.py | 42 + .../pip/_internal/commands/install.py | 740 ++ .../pip/_internal/commands/list.py | 319 + .../pip/_internal/commands/search.py | 162 + .../pip/_internal/commands/show.py | 181 + .../pip/_internal/commands/uninstall.py | 92 + .../pip/_internal/commands/wheel.py | 178 + .../pip/_internal/configuration.py | 403 + .../pip/_internal/distributions/__init__.py | 20 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 737 bytes .../__pycache__/base.cpython-39.pyc | Bin 0 -> 1793 bytes .../__pycache__/installed.cpython-39.pyc | Bin 0 -> 1138 bytes .../__pycache__/sdist.cpython-39.pyc | Bin 0 -> 3401 bytes .../__pycache__/wheel.cpython-39.pyc | Bin 0 -> 1482 bytes .../pip/_internal/distributions/base.py | 39 + .../pip/_internal/distributions/installed.py | 22 + .../pip/_internal/distributions/sdist.py | 95 + .../pip/_internal/distributions/wheel.py | 34 + .../site-packages/pip/_internal/exceptions.py | 397 + .../pip/_internal/index/__init__.py | 2 + .../index/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 195 bytes .../__pycache__/collector.cpython-39.pyc | Bin 0 -> 15051 bytes .../__pycache__/package_finder.cpython-39.pyc | Bin 0 -> 26578 bytes .../index/__pycache__/sources.cpython-39.pyc | Bin 0 -> 7160 bytes .../pip/_internal/index/collector.py | 556 ++ .../pip/_internal/index/package_finder.py | 1012 ++ .../pip/_internal/index/sources.py | 224 + .../pip/_internal/locations/__init__.py | 184 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3651 bytes .../__pycache__/_distutils.cpython-39.pyc | Bin 0 -> 3848 bytes .../__pycache__/_sysconfig.cpython-39.pyc | Bin 0 -> 4466 bytes .../locations/__pycache__/base.cpython-39.pyc | Bin 0 -> 1179 bytes .../pip/_internal/locations/_distutils.py | 150 + .../pip/_internal/locations/_sysconfig.py | 180 + .../pip/_internal/locations/base.py | 48 + .../Lib/site-packages/pip/_internal/main.py | 13 + .../pip/_internal/metadata/__init__.py | 43 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1694 bytes .../metadata/__pycache__/base.cpython-39.pyc | Bin 0 -> 5268 bytes .../__pycache__/pkg_resources.cpython-39.pyc | Bin 0 -> 4222 bytes .../pip/_internal/metadata/base.py | 142 + .../pip/_internal/metadata/pkg_resources.py | 126 + .../pip/_internal/models/__init__.py | 2 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 229 bytes .../__pycache__/candidate.cpython-39.pyc | Bin 0 -> 1342 bytes .../__pycache__/direct_url.cpython-39.pyc | Bin 0 -> 6255 bytes .../__pycache__/format_control.cpython-39.pyc | Bin 0 -> 2499 bytes .../models/__pycache__/index.cpython-39.pyc | Bin 0 -> 1152 bytes .../models/__pycache__/link.cpython-39.pyc | Bin 0 -> 7156 bytes .../models/__pycache__/scheme.cpython-39.pyc | Bin 0 -> 907 bytes .../__pycache__/search_scope.cpython-39.pyc | Bin 0 -> 3308 bytes .../selection_prefs.cpython-39.pyc | Bin 0 -> 1542 bytes .../__pycache__/target_python.cpython-39.pyc | Bin 0 -> 3239 bytes .../models/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 4154 bytes .../pip/_internal/models/candidate.py | 34 + .../pip/_internal/models/direct_url.py | 233 + .../pip/_internal/models/format_control.py | 86 + .../pip/_internal/models/index.py | 34 + .../pip/_internal/models/link.py | 248 + .../pip/_internal/models/scheme.py | 31 + .../pip/_internal/models/search_scope.py | 131 + .../pip/_internal/models/selection_prefs.py | 47 + .../pip/_internal/models/target_python.py | 114 + .../pip/_internal/models/wheel.py | 95 + .../pip/_internal/network/__init__.py | 2 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 217 bytes .../network/__pycache__/auth.cpython-39.pyc | Bin 0 -> 7014 bytes .../network/__pycache__/cache.cpython-39.pyc | Bin 0 -> 2696 bytes .../__pycache__/download.cpython-39.pyc | Bin 0 -> 5056 bytes .../__pycache__/lazy_wheel.cpython-39.pyc | Bin 0 -> 7881 bytes .../__pycache__/session.cpython-39.pyc | Bin 0 -> 9464 bytes .../network/__pycache__/utils.cpython-39.pyc | Bin 0 -> 1283 bytes .../network/__pycache__/xmlrpc.cpython-39.pyc | Bin 0 -> 1862 bytes .../pip/_internal/network/auth.py | 312 + .../pip/_internal/network/cache.py | 76 + .../pip/_internal/network/download.py | 196 + .../pip/_internal/network/lazy_wheel.py | 224 + .../pip/_internal/network/session.py | 449 + .../pip/_internal/network/utils.py | 95 + .../pip/_internal/network/xmlrpc.py | 49 + .../pip/_internal/operations/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 165 bytes .../__pycache__/check.cpython-39.pyc | Bin 0 -> 3661 bytes .../__pycache__/freeze.cpython-39.pyc | Bin 0 -> 5614 bytes .../__pycache__/prepare.cpython-39.pyc | Bin 0 -> 14201 bytes .../_internal/operations/build/__init__.py | 0 .../build/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 171 bytes .../build/__pycache__/metadata.cpython-39.pyc | Bin 0 -> 1117 bytes .../metadata_legacy.cpython-39.pyc | Bin 0 -> 1891 bytes .../build/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 1096 bytes .../__pycache__/wheel_legacy.cpython-39.pyc | Bin 0 -> 2490 bytes .../_internal/operations/build/metadata.py | 35 + .../operations/build/metadata_legacy.py | 74 + .../pip/_internal/operations/build/wheel.py | 38 + .../operations/build/wheel_legacy.py | 110 + .../pip/_internal/operations/check.py | 153 + .../pip/_internal/operations/freeze.py | 264 + .../_internal/operations/install/__init__.py | 2 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 229 bytes .../editable_legacy.cpython-39.pyc | Bin 0 -> 1272 bytes .../install/__pycache__/legacy.cpython-39.pyc | Bin 0 -> 3160 bytes .../install/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 20782 bytes .../operations/install/editable_legacy.py | 47 + .../_internal/operations/install/legacy.py | 125 + .../pip/_internal/operations/install/wheel.py | 819 ++ .../pip/_internal/operations/prepare.py | 655 ++ .../site-packages/pip/_internal/pyproject.py | 183 + .../pip/_internal/req/__init__.py | 98 + .../req/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2312 bytes .../__pycache__/constructors.cpython-39.pyc | Bin 0 -> 10972 bytes .../req/__pycache__/req_file.cpython-39.pyc | Bin 0 -> 12405 bytes .../__pycache__/req_install.cpython-39.pyc | Bin 0 -> 20483 bytes .../req/__pycache__/req_set.cpython-39.pyc | Bin 0 -> 5649 bytes .../__pycache__/req_tracker.cpython-39.pyc | Bin 0 -> 3994 bytes .../__pycache__/req_uninstall.cpython-39.pyc | Bin 0 -> 17430 bytes .../pip/_internal/req/constructors.py | 486 + .../pip/_internal/req/req_file.py | 551 ++ .../pip/_internal/req/req_install.py | 878 ++ .../pip/_internal/req/req_set.py | 199 + .../pip/_internal/req/req_tracker.py | 140 + .../pip/_internal/req/req_uninstall.py | 640 ++ .../pip/_internal/resolution/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 165 bytes .../__pycache__/base.cpython-39.pyc | Bin 0 -> 908 bytes .../pip/_internal/resolution/base.py | 16 + .../_internal/resolution/legacy/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 172 bytes .../__pycache__/resolver.cpython-39.pyc | Bin 0 -> 11445 bytes .../_internal/resolution/legacy/resolver.py | 462 + .../resolution/resolvelib/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 176 bytes .../__pycache__/base.cpython-39.pyc | Bin 0 -> 6278 bytes .../__pycache__/candidates.cpython-39.pyc | Bin 0 -> 17858 bytes .../__pycache__/factory.cpython-39.pyc | Bin 0 -> 16325 bytes .../found_candidates.cpython-39.pyc | Bin 0 -> 4624 bytes .../__pycache__/provider.cpython-39.pyc | Bin 0 -> 6544 bytes .../__pycache__/reporter.cpython-39.pyc | Bin 0 -> 3108 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 0 -> 7013 bytes .../__pycache__/resolver.cpython-39.pyc | Bin 0 -> 8020 bytes .../_internal/resolution/resolvelib/base.py | 165 + .../resolution/resolvelib/candidates.py | 604 ++ .../resolution/resolvelib/factory.py | 661 ++ .../resolution/resolvelib/found_candidates.py | 145 + .../resolution/resolvelib/provider.py | 175 + .../resolution/resolvelib/reporter.py | 78 + .../resolution/resolvelib/requirements.py | 198 + .../resolution/resolvelib/resolver.py | 305 + .../pip/_internal/self_outdated_check.py | 187 + .../pip/_internal/utils/__init__.py | 0 .../utils/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 160 bytes .../utils/__pycache__/appdirs.cpython-39.pyc | Bin 0 -> 1225 bytes .../utils/__pycache__/compat.cpython-39.pyc | Bin 0 -> 1427 bytes .../compatibility_tags.cpython-39.pyc | Bin 0 -> 3803 bytes .../utils/__pycache__/datetime.cpython-39.pyc | Bin 0 -> 431 bytes .../__pycache__/deprecation.cpython-39.pyc | Bin 0 -> 2726 bytes .../direct_url_helpers.cpython-39.pyc | Bin 0 -> 2480 bytes .../__pycache__/distutils_args.cpython-39.pyc | Bin 0 -> 1025 bytes .../utils/__pycache__/encoding.cpython-39.pyc | Bin 0 -> 1190 bytes .../__pycache__/entrypoints.cpython-39.pyc | Bin 0 -> 1229 bytes .../__pycache__/filesystem.cpython-39.pyc | Bin 0 -> 4899 bytes .../__pycache__/filetypes.cpython-39.pyc | Bin 0 -> 772 bytes .../utils/__pycache__/glibc.cpython-39.pyc | Bin 0 -> 1582 bytes .../utils/__pycache__/hashes.cpython-39.pyc | Bin 0 -> 4964 bytes .../inject_securetransport.cpython-39.pyc | Bin 0 -> 933 bytes .../utils/__pycache__/logging.cpython-39.pyc | Bin 0 -> 8884 bytes .../utils/__pycache__/misc.cpython-39.pyc | Bin 0 -> 21488 bytes .../utils/__pycache__/models.cpython-39.pyc | Bin 0 -> 1864 bytes .../__pycache__/packaging.cpython-39.pyc | Bin 0 -> 2488 bytes .../utils/__pycache__/parallel.cpython-39.pyc | Bin 0 -> 3005 bytes .../__pycache__/pkg_resources.cpython-39.pyc | Bin 0 -> 1686 bytes .../setuptools_build.cpython-39.pyc | Bin 0 -> 2930 bytes .../__pycache__/subprocess.cpython-39.pyc | Bin 0 -> 5653 bytes .../utils/__pycache__/temp_dir.cpython-39.pyc | Bin 0 -> 6804 bytes .../__pycache__/unpacking.cpython-39.pyc | Bin 0 -> 6425 bytes .../utils/__pycache__/urls.cpython-39.pyc | Bin 0 -> 1316 bytes .../__pycache__/virtualenv.cpython-39.pyc | Bin 0 -> 3183 bytes .../utils/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 5934 bytes .../pip/_internal/utils/appdirs.py | 38 + .../pip/_internal/utils/compat.py | 65 + .../pip/_internal/utils/compatibility_tags.py | 174 + .../pip/_internal/utils/datetime.py | 12 + .../pip/_internal/utils/deprecation.py | 102 + .../pip/_internal/utils/direct_url_helpers.py | 117 + .../pip/_internal/utils/distutils_args.py | 43 + .../pip/_internal/utils/encoding.py | 37 + .../pip/_internal/utils/entrypoints.py | 28 + .../pip/_internal/utils/filesystem.py | 193 + .../pip/_internal/utils/filetypes.py | 28 + .../pip/_internal/utils/glibc.py | 92 + .../pip/_internal/utils/hashes.py | 165 + .../_internal/utils/inject_securetransport.py | 36 + .../pip/_internal/utils/logging.py | 387 + .../site-packages/pip/_internal/utils/misc.py | 821 ++ .../pip/_internal/utils/models.py | 47 + .../pip/_internal/utils/packaging.py | 89 + .../pip/_internal/utils/parallel.py | 101 + .../pip/_internal/utils/pkg_resources.py | 40 + .../pip/_internal/utils/setuptools_build.py | 173 + .../pip/_internal/utils/subprocess.py | 281 + .../pip/_internal/utils/temp_dir.py | 260 + .../pip/_internal/utils/unpacking.py | 267 + .../site-packages/pip/_internal/utils/urls.py | 49 + .../pip/_internal/utils/virtualenv.py | 111 + .../pip/_internal/utils/wheel.py | 189 + .../pip/_internal/vcs/__init__.py | 14 + .../vcs/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 453 bytes .../vcs/__pycache__/bazaar.cpython-39.pyc | Bin 0 -> 2969 bytes .../vcs/__pycache__/git.cpython-39.pyc | Bin 0 -> 9945 bytes .../vcs/__pycache__/mercurial.cpython-39.pyc | Bin 0 -> 4590 bytes .../vcs/__pycache__/subversion.cpython-39.pyc | Bin 0 -> 7924 bytes .../__pycache__/versioncontrol.cpython-39.pyc | Bin 0 -> 19069 bytes .../site-packages/pip/_internal/vcs/bazaar.py | 96 + .../site-packages/pip/_internal/vcs/git.py | 450 + .../pip/_internal/vcs/mercurial.py | 158 + .../pip/_internal/vcs/subversion.py | 329 + .../pip/_internal/vcs/versioncontrol.py | 715 ++ .../pip/_internal/wheel_builder.py | 360 + .../Lib/site-packages/pip/_vendor/__init__.py | 113 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2915 bytes .../__pycache__/appdirs.cpython-39.pyc | Bin 0 -> 21368 bytes .../_vendor/__pycache__/distro.cpython-39.pyc | Bin 0 -> 36847 bytes .../__pycache__/pyparsing.cpython-39.pyc | Bin 0 -> 240404 bytes .../_vendor/__pycache__/six.cpython-39.pyc | Bin 0 -> 26914 bytes .../Lib/site-packages/pip/_vendor/appdirs.py | 633 ++ .../pip/_vendor/cachecontrol/__init__.py | 11 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 518 bytes .../__pycache__/_cmd.cpython-39.pyc | Bin 0 -> 1539 bytes .../__pycache__/adapter.cpython-39.pyc | Bin 0 -> 3044 bytes .../__pycache__/cache.cpython-39.pyc | Bin 0 -> 1791 bytes .../__pycache__/compat.cpython-39.pyc | Bin 0 -> 715 bytes .../__pycache__/controller.cpython-39.pyc | Bin 0 -> 7732 bytes .../__pycache__/filewrapper.cpython-39.pyc | Bin 0 -> 2140 bytes .../__pycache__/heuristics.cpython-39.pyc | Bin 0 -> 4672 bytes .../__pycache__/serialize.cpython-39.pyc | Bin 0 -> 4191 bytes .../__pycache__/wrapper.cpython-39.pyc | Bin 0 -> 642 bytes .../pip/_vendor/cachecontrol/_cmd.py | 57 + .../pip/_vendor/cachecontrol/adapter.py | 133 + .../pip/_vendor/cachecontrol/cache.py | 39 + .../_vendor/cachecontrol/caches/__init__.py | 2 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 262 bytes .../__pycache__/file_cache.cpython-39.pyc | Bin 0 -> 3278 bytes .../__pycache__/redis_cache.cpython-39.pyc | Bin 0 -> 1534 bytes .../_vendor/cachecontrol/caches/file_cache.py | 146 + .../cachecontrol/caches/redis_cache.py | 33 + .../pip/_vendor/cachecontrol/compat.py | 29 + .../pip/_vendor/cachecontrol/controller.py | 376 + .../pip/_vendor/cachecontrol/filewrapper.py | 80 + .../pip/_vendor/cachecontrol/heuristics.py | 135 + .../pip/_vendor/cachecontrol/serialize.py | 188 + .../pip/_vendor/cachecontrol/wrapper.py | 29 + .../pip/_vendor/certifi/__init__.py | 3 + .../pip/_vendor/certifi/__main__.py | 12 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 244 bytes .../__pycache__/__main__.cpython-39.pyc | Bin 0 -> 421 bytes .../certifi/__pycache__/core.cpython-39.pyc | Bin 0 -> 1512 bytes .../pip/_vendor/certifi/cacert.pem | 4325 +++++++++ .../site-packages/pip/_vendor/certifi/core.py | 76 + .../pip/_vendor/chardet/__init__.py | 83 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1868 bytes .../__pycache__/big5freq.cpython-39.pyc | Bin 0 -> 27147 bytes .../__pycache__/big5prober.cpython-39.pyc | Bin 0 -> 1102 bytes .../chardistribution.cpython-39.pyc | Bin 0 -> 6188 bytes .../charsetgroupprober.cpython-39.pyc | Bin 0 -> 2229 bytes .../__pycache__/charsetprober.cpython-39.pyc | Bin 0 -> 3451 bytes .../codingstatemachine.cpython-39.pyc | Bin 0 -> 2878 bytes .../chardet/__pycache__/compat.cpython-39.pyc | Bin 0 -> 367 bytes .../__pycache__/cp949prober.cpython-39.pyc | Bin 0 -> 1109 bytes .../chardet/__pycache__/enums.cpython-39.pyc | Bin 0 -> 2616 bytes .../__pycache__/escprober.cpython-39.pyc | Bin 0 -> 2601 bytes .../chardet/__pycache__/escsm.cpython-39.pyc | Bin 0 -> 7050 bytes .../__pycache__/eucjpprober.cpython-39.pyc | Bin 0 -> 2415 bytes .../__pycache__/euckrfreq.cpython-39.pyc | Bin 0 -> 12031 bytes .../__pycache__/euckrprober.cpython-39.pyc | Bin 0 -> 1110 bytes .../__pycache__/euctwfreq.cpython-39.pyc | Bin 0 -> 27151 bytes .../__pycache__/euctwprober.cpython-39.pyc | Bin 0 -> 1110 bytes .../__pycache__/gb2312freq.cpython-39.pyc | Bin 0 -> 19075 bytes .../__pycache__/gb2312prober.cpython-39.pyc | Bin 0 -> 1118 bytes .../__pycache__/hebrewprober.cpython-39.pyc | Bin 0 -> 2987 bytes .../__pycache__/jisfreq.cpython-39.pyc | Bin 0 -> 22103 bytes .../chardet/__pycache__/jpcntx.cpython-39.pyc | Bin 0 -> 37576 bytes .../langbulgarianmodel.cpython-39.pyc | Bin 0 -> 21778 bytes .../__pycache__/langgreekmodel.cpython-39.pyc | Bin 0 -> 20454 bytes .../langhebrewmodel.cpython-39.pyc | Bin 0 -> 20522 bytes .../langhungarianmodel.cpython-39.pyc | Bin 0 -> 21723 bytes .../langrussianmodel.cpython-39.pyc | Bin 0 -> 26326 bytes .../__pycache__/langthaimodel.cpython-39.pyc | Bin 0 -> 20698 bytes .../langturkishmodel.cpython-39.pyc | Bin 0 -> 20538 bytes .../__pycache__/latin1prober.cpython-39.pyc | Bin 0 -> 2923 bytes .../mbcharsetprober.cpython-39.pyc | Bin 0 -> 2230 bytes .../mbcsgroupprober.cpython-39.pyc | Bin 0 -> 1099 bytes .../chardet/__pycache__/mbcssm.cpython-39.pyc | Bin 0 -> 15686 bytes .../sbcharsetprober.cpython-39.pyc | Bin 0 -> 3083 bytes .../sbcsgroupprober.cpython-39.pyc | Bin 0 -> 1668 bytes .../__pycache__/sjisprober.cpython-39.pyc | Bin 0 -> 2451 bytes .../universaldetector.cpython-39.pyc | Bin 0 -> 5799 bytes .../__pycache__/utf8prober.cpython-39.pyc | Bin 0 -> 1960 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 407 bytes .../pip/_vendor/chardet/big5freq.py | 386 + .../pip/_vendor/chardet/big5prober.py | 47 + .../pip/_vendor/chardet/chardistribution.py | 233 + .../pip/_vendor/chardet/charsetgroupprober.py | 107 + .../pip/_vendor/chardet/charsetprober.py | 145 + .../pip/_vendor/chardet/cli/__init__.py | 1 + .../cli/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 164 bytes .../cli/__pycache__/chardetect.cpython-39.pyc | Bin 0 -> 2658 bytes .../pip/_vendor/chardet/cli/chardetect.py | 84 + .../pip/_vendor/chardet/codingstatemachine.py | 88 + .../pip/_vendor/chardet/compat.py | 36 + .../pip/_vendor/chardet/cp949prober.py | 49 + .../pip/_vendor/chardet/enums.py | 76 + .../pip/_vendor/chardet/escprober.py | 101 + .../pip/_vendor/chardet/escsm.py | 246 + .../pip/_vendor/chardet/eucjpprober.py | 92 + .../pip/_vendor/chardet/euckrfreq.py | 195 + .../pip/_vendor/chardet/euckrprober.py | 47 + .../pip/_vendor/chardet/euctwfreq.py | 387 + .../pip/_vendor/chardet/euctwprober.py | 46 + .../pip/_vendor/chardet/gb2312freq.py | 283 + .../pip/_vendor/chardet/gb2312prober.py | 46 + .../pip/_vendor/chardet/hebrewprober.py | 292 + .../pip/_vendor/chardet/jisfreq.py | 325 + .../pip/_vendor/chardet/jpcntx.py | 233 + .../pip/_vendor/chardet/langbulgarianmodel.py | 4650 +++++++++ .../pip/_vendor/chardet/langgreekmodel.py | 4398 +++++++++ .../pip/_vendor/chardet/langhebrewmodel.py | 4383 +++++++++ .../pip/_vendor/chardet/langhungarianmodel.py | 4650 +++++++++ .../pip/_vendor/chardet/langrussianmodel.py | 5718 +++++++++++ .../pip/_vendor/chardet/langthaimodel.py | 4383 +++++++++ .../pip/_vendor/chardet/langturkishmodel.py | 4383 +++++++++ .../pip/_vendor/chardet/latin1prober.py | 145 + .../pip/_vendor/chardet/mbcharsetprober.py | 91 + .../pip/_vendor/chardet/mbcsgroupprober.py | 54 + .../pip/_vendor/chardet/mbcssm.py | 572 ++ .../pip/_vendor/chardet/metadata/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 169 bytes .../__pycache__/languages.cpython-39.pyc | Bin 0 -> 7900 bytes .../pip/_vendor/chardet/metadata/languages.py | 310 + .../pip/_vendor/chardet/sbcharsetprober.py | 145 + .../pip/_vendor/chardet/sbcsgroupprober.py | 83 + .../pip/_vendor/chardet/sjisprober.py | 92 + .../pip/_vendor/chardet/universaldetector.py | 286 + .../pip/_vendor/chardet/utf8prober.py | 82 + .../pip/_vendor/chardet/version.py | 9 + .../pip/_vendor/colorama/__init__.py | 6 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 412 bytes .../colorama/__pycache__/ansi.cpython-39.pyc | Bin 0 -> 3197 bytes .../__pycache__/ansitowin32.cpython-39.pyc | Bin 0 -> 7663 bytes .../__pycache__/initialise.cpython-39.pyc | Bin 0 -> 1679 bytes .../colorama/__pycache__/win32.cpython-39.pyc | Bin 0 -> 3911 bytes .../__pycache__/winterm.cpython-39.pyc | Bin 0 -> 4633 bytes .../pip/_vendor/colorama/ansi.py | 102 + .../pip/_vendor/colorama/ansitowin32.py | 258 + .../pip/_vendor/colorama/initialise.py | 80 + .../pip/_vendor/colorama/win32.py | 152 + .../pip/_vendor/colorama/winterm.py | 169 + .../pip/_vendor/distlib/__init__.py | 23 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1025 bytes .../distlib/__pycache__/compat.cpython-39.pyc | Bin 0 -> 32127 bytes .../__pycache__/database.cpython-39.pyc | Bin 0 -> 42449 bytes .../distlib/__pycache__/index.cpython-39.pyc | Bin 0 -> 17470 bytes .../__pycache__/locators.cpython-39.pyc | Bin 0 -> 38458 bytes .../__pycache__/manifest.cpython-39.pyc | Bin 0 -> 10161 bytes .../__pycache__/markers.cpython-39.pyc | Bin 0 -> 4452 bytes .../__pycache__/metadata.cpython-39.pyc | Bin 0 -> 26378 bytes .../__pycache__/resources.cpython-39.pyc | Bin 0 -> 10991 bytes .../__pycache__/scripts.cpython-39.pyc | Bin 0 -> 10899 bytes .../distlib/__pycache__/util.cpython-39.pyc | Bin 0 -> 48171 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 20276 bytes .../distlib/__pycache__/wheel.cpython-39.pyc | Bin 0 -> 26360 bytes .../pip/_vendor/distlib/_backport/__init__.py | 6 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 452 bytes .../_backport/__pycache__/misc.cpython-39.pyc | Bin 0 -> 1072 bytes .../__pycache__/shutil.cpython-39.pyc | Bin 0 -> 21646 bytes .../__pycache__/sysconfig.cpython-39.pyc | Bin 0 -> 15936 bytes .../__pycache__/tarfile.cpython-39.pyc | Bin 0 -> 62700 bytes .../pip/_vendor/distlib/_backport/misc.py | 41 + .../pip/_vendor/distlib/_backport/shutil.py | 764 ++ .../_vendor/distlib/_backport/sysconfig.cfg | 84 + .../_vendor/distlib/_backport/sysconfig.py | 786 ++ .../pip/_vendor/distlib/_backport/tarfile.py | 2607 +++++ .../pip/_vendor/distlib/compat.py | 1120 +++ .../pip/_vendor/distlib/database.py | 1339 +++ .../pip/_vendor/distlib/index.py | 516 + .../pip/_vendor/distlib/locators.py | 1302 +++ .../pip/_vendor/distlib/manifest.py | 393 + .../pip/_vendor/distlib/markers.py | 131 + .../pip/_vendor/distlib/metadata.py | 1056 ++ .../pip/_vendor/distlib/resources.py | 355 + .../pip/_vendor/distlib/scripts.py | 419 + .../site-packages/pip/_vendor/distlib/t32.exe | Bin 0 -> 96768 bytes .../site-packages/pip/_vendor/distlib/t64.exe | Bin 0 -> 105984 bytes .../site-packages/pip/_vendor/distlib/util.py | 1761 ++++ .../pip/_vendor/distlib/version.py | 736 ++ .../site-packages/pip/_vendor/distlib/w32.exe | Bin 0 -> 90112 bytes .../site-packages/pip/_vendor/distlib/w64.exe | Bin 0 -> 99840 bytes .../pip/_vendor/distlib/wheel.py | 1018 ++ .../Lib/site-packages/pip/_vendor/distro.py | 1230 +++ .../pip/_vendor/html5lib/__init__.py | 35 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1271 bytes .../__pycache__/_ihatexml.cpython-39.pyc | Bin 0 -> 13740 bytes .../__pycache__/_inputstream.cpython-39.pyc | Bin 0 -> 21599 bytes .../__pycache__/_tokenizer.cpython-39.pyc | Bin 0 -> 39694 bytes .../__pycache__/_utils.cpython-39.pyc | Bin 0 -> 4771 bytes .../__pycache__/constants.cpython-39.pyc | Bin 0 -> 66309 bytes .../__pycache__/html5parser.cpython-39.pyc | Bin 0 -> 90980 bytes .../__pycache__/serializer.cpython-39.pyc | Bin 0 -> 10782 bytes .../pip/_vendor/html5lib/_ihatexml.py | 289 + .../pip/_vendor/html5lib/_inputstream.py | 918 ++ .../pip/_vendor/html5lib/_tokenizer.py | 1735 ++++ .../pip/_vendor/html5lib/_trie/__init__.py | 5 + .../_trie/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 321 bytes .../_trie/__pycache__/_base.cpython-39.pyc | Bin 0 -> 1565 bytes .../_trie/__pycache__/py.cpython-39.pyc | Bin 0 -> 2226 bytes .../pip/_vendor/html5lib/_trie/_base.py | 40 + .../pip/_vendor/html5lib/_trie/py.py | 67 + .../pip/_vendor/html5lib/_utils.py | 159 + .../pip/_vendor/html5lib/constants.py | 2946 ++++++ .../pip/_vendor/html5lib/filters/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 169 bytes .../alphabeticalattributes.cpython-39.pyc | Bin 0 -> 1291 bytes .../filters/__pycache__/base.cpython-39.pyc | Bin 0 -> 839 bytes .../inject_meta_charset.cpython-39.pyc | Bin 0 -> 1845 bytes .../filters/__pycache__/lint.cpython-39.pyc | Bin 0 -> 2587 bytes .../__pycache__/optionaltags.cpython-39.pyc | Bin 0 -> 2732 bytes .../__pycache__/sanitizer.cpython-39.pyc | Bin 0 -> 16855 bytes .../__pycache__/whitespace.cpython-39.pyc | Bin 0 -> 1337 bytes .../filters/alphabeticalattributes.py | 29 + .../pip/_vendor/html5lib/filters/base.py | 12 + .../html5lib/filters/inject_meta_charset.py | 73 + .../pip/_vendor/html5lib/filters/lint.py | 93 + .../_vendor/html5lib/filters/optionaltags.py | 207 + .../pip/_vendor/html5lib/filters/sanitizer.py | 916 ++ .../_vendor/html5lib/filters/whitespace.py | 38 + .../pip/_vendor/html5lib/html5parser.py | 2795 ++++++ .../pip/_vendor/html5lib/serializer.py | 409 + .../_vendor/html5lib/treeadapters/__init__.py | 30 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 906 bytes .../__pycache__/genshi.cpython-39.pyc | Bin 0 -> 1514 bytes .../__pycache__/sax.cpython-39.pyc | Bin 0 -> 1433 bytes .../_vendor/html5lib/treeadapters/genshi.py | 54 + .../pip/_vendor/html5lib/treeadapters/sax.py | 50 + .../_vendor/html5lib/treebuilders/__init__.py | 88 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3301 bytes .../__pycache__/base.cpython-39.pyc | Bin 0 -> 11285 bytes .../__pycache__/dom.cpython-39.pyc | Bin 0 -> 9422 bytes .../__pycache__/etree.cpython-39.pyc | Bin 0 -> 11790 bytes .../__pycache__/etree_lxml.cpython-39.pyc | Bin 0 -> 12973 bytes .../pip/_vendor/html5lib/treebuilders/base.py | 417 + .../pip/_vendor/html5lib/treebuilders/dom.py | 239 + .../_vendor/html5lib/treebuilders/etree.py | 343 + .../html5lib/treebuilders/etree_lxml.py | 392 + .../_vendor/html5lib/treewalkers/__init__.py | 154 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3967 bytes .../__pycache__/base.cpython-39.pyc | Bin 0 -> 6966 bytes .../__pycache__/dom.cpython-39.pyc | Bin 0 -> 1701 bytes .../__pycache__/etree.cpython-39.pyc | Bin 0 -> 3463 bytes .../__pycache__/etree_lxml.cpython-39.pyc | Bin 0 -> 6600 bytes .../__pycache__/genshi.cpython-39.pyc | Bin 0 -> 1857 bytes .../pip/_vendor/html5lib/treewalkers/base.py | 252 + .../pip/_vendor/html5lib/treewalkers/dom.py | 43 + .../pip/_vendor/html5lib/treewalkers/etree.py | 131 + .../html5lib/treewalkers/etree_lxml.py | 215 + .../_vendor/html5lib/treewalkers/genshi.py | 69 + .../pip/_vendor/idna/__init__.py | 2 + .../idna/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 226 bytes .../idna/__pycache__/codec.cpython-39.pyc | Bin 0 -> 2760 bytes .../idna/__pycache__/compat.cpython-39.pyc | Bin 0 -> 598 bytes .../idna/__pycache__/core.cpython-39.pyc | Bin 0 -> 9054 bytes .../idna/__pycache__/idnadata.cpython-39.pyc | Bin 0 -> 22107 bytes .../idna/__pycache__/intranges.cpython-39.pyc | Bin 0 -> 1778 bytes .../__pycache__/package_data.cpython-39.pyc | Bin 0 -> 180 bytes .../idna/__pycache__/uts46data.cpython-39.pyc | Bin 0 -> 146115 bytes .../site-packages/pip/_vendor/idna/codec.py | 110 + .../site-packages/pip/_vendor/idna/compat.py | 12 + .../site-packages/pip/_vendor/idna/core.py | 396 + .../pip/_vendor/idna/idnadata.py | 2050 ++++ .../pip/_vendor/idna/intranges.py | 53 + .../pip/_vendor/idna/package_data.py | 2 + .../pip/_vendor/idna/uts46data.py | 8356 ++++++++++++++++ .../pip/_vendor/msgpack/__init__.py | 54 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1383 bytes .../__pycache__/_version.cpython-39.pyc | Bin 0 -> 187 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 1821 bytes .../msgpack/__pycache__/ext.cpython-39.pyc | Bin 0 -> 6249 bytes .../__pycache__/fallback.cpython-39.pyc | Bin 0 -> 26695 bytes .../pip/_vendor/msgpack/_version.py | 1 + .../pip/_vendor/msgpack/exceptions.py | 48 + .../site-packages/pip/_vendor/msgpack/ext.py | 193 + .../pip/_vendor/msgpack/fallback.py | 1087 +++ .../pip/_vendor/packaging/__about__.py | 27 + .../pip/_vendor/packaging/__init__.py | 26 + .../__pycache__/__about__.cpython-39.pyc | Bin 0 -> 658 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 514 bytes .../__pycache__/_compat.cpython-39.pyc | Bin 0 -> 1112 bytes .../__pycache__/_structures.cpython-39.pyc | Bin 0 -> 2866 bytes .../__pycache__/_typing.cpython-39.pyc | Bin 0 -> 1469 bytes .../__pycache__/markers.cpython-39.pyc | Bin 0 -> 9240 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 0 -> 4113 bytes .../__pycache__/specifiers.cpython-39.pyc | Bin 0 -> 20895 bytes .../packaging/__pycache__/tags.cpython-39.pyc | Bin 0 -> 18512 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 3580 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 12644 bytes .../pip/_vendor/packaging/_compat.py | 38 + .../pip/_vendor/packaging/_structures.py | 86 + .../pip/_vendor/packaging/_typing.py | 48 + .../pip/_vendor/packaging/markers.py | 336 + .../pip/_vendor/packaging/requirements.py | 160 + .../pip/_vendor/packaging/specifiers.py | 864 ++ .../pip/_vendor/packaging/tags.py | 866 ++ .../pip/_vendor/packaging/utils.py | 138 + .../pip/_vendor/packaging/version.py | 556 ++ .../pip/_vendor/pep517/__init__.py | 6 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 282 bytes .../pep517/__pycache__/build.cpython-39.pyc | Bin 0 -> 3531 bytes .../pep517/__pycache__/check.cpython-39.pyc | Bin 0 -> 5066 bytes .../__pycache__/colorlog.cpython-39.pyc | Bin 0 -> 2907 bytes .../pep517/__pycache__/compat.cpython-39.pyc | Bin 0 -> 1084 bytes .../__pycache__/dirtools.cpython-39.pyc | Bin 0 -> 1316 bytes .../__pycache__/envbuild.cpython-39.pyc | Bin 0 -> 4449 bytes .../pep517/__pycache__/meta.cpython-39.pyc | Bin 0 -> 2889 bytes .../__pycache__/wrappers.cpython-39.pyc | Bin 0 -> 10449 bytes .../site-packages/pip/_vendor/pep517/build.py | 127 + .../site-packages/pip/_vendor/pep517/check.py | 206 + .../pip/_vendor/pep517/colorlog.py | 115 + .../pip/_vendor/pep517/compat.py | 34 + .../pip/_vendor/pep517/dirtools.py | 44 + .../pip/_vendor/pep517/envbuild.py | 167 + .../pip/_vendor/pep517/in_process/__init__.py | 17 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 884 bytes .../__pycache__/_in_process.cpython-39.pyc | Bin 0 -> 8246 bytes .../_vendor/pep517/in_process/_in_process.py | 280 + .../site-packages/pip/_vendor/pep517/meta.py | 92 + .../pip/_vendor/pep517/wrappers.py | 318 + .../pip/_vendor/pkg_resources/__init__.py | 3296 +++++++ .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 100300 bytes .../__pycache__/py31compat.cpython-39.pyc | Bin 0 -> 619 bytes .../pip/_vendor/pkg_resources/py31compat.py | 23 + .../pip/_vendor/progress/__init__.py | 177 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 5626 bytes .../progress/__pycache__/bar.cpython-39.pyc | Bin 0 -> 2608 bytes .../__pycache__/counter.cpython-39.pyc | Bin 0 -> 1442 bytes .../__pycache__/spinner.cpython-39.pyc | Bin 0 -> 1359 bytes .../site-packages/pip/_vendor/progress/bar.py | 91 + .../pip/_vendor/progress/counter.py | 41 + .../pip/_vendor/progress/spinner.py | 43 + .../site-packages/pip/_vendor/pyparsing.py | 7107 ++++++++++++++ .../pip/_vendor/requests/__init__.py | 142 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3638 bytes .../__pycache__/__version__.cpython-39.pyc | Bin 0 -> 524 bytes .../_internal_utils.cpython-39.pyc | Bin 0 -> 1271 bytes .../__pycache__/adapters.cpython-39.pyc | Bin 0 -> 16942 bytes .../requests/__pycache__/api.cpython-39.pyc | Bin 0 -> 6728 bytes .../requests/__pycache__/auth.cpython-39.pyc | Bin 0 -> 8300 bytes .../requests/__pycache__/certs.cpython-39.pyc | Bin 0 -> 602 bytes .../__pycache__/compat.cpython-39.pyc | Bin 0 -> 1581 bytes .../__pycache__/cookies.cpython-39.pyc | Bin 0 -> 18791 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 5214 bytes .../requests/__pycache__/help.cpython-39.pyc | Bin 0 -> 2685 bytes .../requests/__pycache__/hooks.cpython-39.pyc | Bin 0 -> 959 bytes .../__pycache__/models.cpython-39.pyc | Bin 0 -> 23908 bytes .../__pycache__/packages.cpython-39.pyc | Bin 0 -> 471 bytes .../__pycache__/sessions.cpython-39.pyc | Bin 0 -> 19813 bytes .../__pycache__/status_codes.cpython-39.pyc | Bin 0 -> 4208 bytes .../__pycache__/structures.cpython-39.pyc | Bin 0 -> 4429 bytes .../requests/__pycache__/utils.cpython-39.pyc | Bin 0 -> 22586 bytes .../pip/_vendor/requests/__version__.py | 14 + .../pip/_vendor/requests/_internal_utils.py | 42 + .../pip/_vendor/requests/adapters.py | 533 ++ .../site-packages/pip/_vendor/requests/api.py | 161 + .../pip/_vendor/requests/auth.py | 305 + .../pip/_vendor/requests/certs.py | 18 + .../pip/_vendor/requests/compat.py | 76 + .../pip/_vendor/requests/cookies.py | 549 ++ .../pip/_vendor/requests/exceptions.py | 123 + .../pip/_vendor/requests/help.py | 119 + .../pip/_vendor/requests/hooks.py | 34 + .../pip/_vendor/requests/models.py | 956 ++ .../pip/_vendor/requests/packages.py | 16 + .../pip/_vendor/requests/sessions.py | 781 ++ .../pip/_vendor/requests/status_codes.py | 123 + .../pip/_vendor/requests/structures.py | 105 + .../pip/_vendor/requests/utils.py | 992 ++ .../pip/_vendor/resolvelib/__init__.py | 26 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 575 bytes .../__pycache__/providers.cpython-39.pyc | Bin 0 -> 6495 bytes .../__pycache__/reporters.cpython-39.pyc | Bin 0 -> 2271 bytes .../__pycache__/resolvers.cpython-39.pyc | Bin 0 -> 15166 bytes .../__pycache__/structs.cpython-39.pyc | Bin 0 -> 6889 bytes .../pip/_vendor/resolvelib/compat/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 170 bytes .../collections_abc.cpython-39.pyc | Bin 0 -> 344 bytes .../resolvelib/compat/collections_abc.py | 6 + .../pip/_vendor/resolvelib/providers.py | 124 + .../pip/_vendor/resolvelib/reporters.py | 37 + .../pip/_vendor/resolvelib/resolvers.py | 474 + .../pip/_vendor/resolvelib/structs.py | 153 + .../Lib/site-packages/pip/_vendor/six.py | 982 ++ .../pip/_vendor/tenacity/__init__.py | 525 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 14647 bytes .../__pycache__/_asyncio.cpython-39.pyc | Bin 0 -> 2172 bytes .../__pycache__/_utils.cpython-39.pyc | Bin 0 -> 3920 bytes .../tenacity/__pycache__/after.cpython-39.pyc | Bin 0 -> 947 bytes .../__pycache__/before.cpython-39.pyc | Bin 0 -> 843 bytes .../__pycache__/before_sleep.cpython-39.pyc | Bin 0 -> 1191 bytes .../__pycache__/compat.cpython-39.pyc | Bin 0 -> 927 bytes .../tenacity/__pycache__/nap.cpython-39.pyc | Bin 0 -> 996 bytes .../tenacity/__pycache__/retry.cpython-39.pyc | Bin 0 -> 7381 bytes .../tenacity/__pycache__/stop.cpython-39.pyc | Bin 0 -> 3757 bytes .../__pycache__/tornadoweb.cpython-39.pyc | Bin 0 -> 1311 bytes .../tenacity/__pycache__/wait.cpython-39.pyc | Bin 0 -> 7314 bytes .../pip/_vendor/tenacity/_asyncio.py | 81 + .../pip/_vendor/tenacity/_utils.py | 159 + .../pip/_vendor/tenacity/after.py | 40 + .../pip/_vendor/tenacity/before.py | 35 + .../pip/_vendor/tenacity/before_sleep.py | 51 + .../pip/_vendor/tenacity/compat.py | 23 + .../site-packages/pip/_vendor/tenacity/nap.py | 40 + .../pip/_vendor/tenacity/retry.py | 192 + .../pip/_vendor/tenacity/stop.py | 95 + .../pip/_vendor/tenacity/tornadoweb.py | 49 + .../pip/_vendor/tenacity/wait.py | 183 + .../pip/_vendor/toml/__init__.py | 25 + .../toml/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 701 bytes .../toml/__pycache__/decoder.cpython-39.pyc | Bin 0 -> 23193 bytes .../toml/__pycache__/encoder.cpython-39.pyc | Bin 0 -> 9376 bytes .../toml/__pycache__/ordered.cpython-39.pyc | Bin 0 -> 940 bytes .../toml/__pycache__/tz.cpython-39.pyc | Bin 0 -> 1242 bytes .../site-packages/pip/_vendor/toml/decoder.py | 1057 ++ .../site-packages/pip/_vendor/toml/encoder.py | 304 + .../site-packages/pip/_vendor/toml/ordered.py | 15 + .../Lib/site-packages/pip/_vendor/toml/tz.py | 24 + .../pip/_vendor/urllib3/__init__.py | 85 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2158 bytes .../__pycache__/_collections.cpython-39.pyc | Bin 0 -> 10753 bytes .../__pycache__/_version.cpython-39.pyc | Bin 0 -> 182 bytes .../__pycache__/connection.cpython-39.pyc | Bin 0 -> 13338 bytes .../__pycache__/connectionpool.cpython-39.pyc | Bin 0 -> 24437 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 11615 bytes .../urllib3/__pycache__/fields.cpython-39.pyc | Bin 0 -> 8130 bytes .../__pycache__/filepost.cpython-39.pyc | Bin 0 -> 2731 bytes .../__pycache__/poolmanager.cpython-39.pyc | Bin 0 -> 15133 bytes .../__pycache__/request.cpython-39.pyc | Bin 0 -> 5594 bytes .../__pycache__/response.cpython-39.pyc | Bin 0 -> 20805 bytes .../pip/_vendor/urllib3/_collections.py | 337 + .../pip/_vendor/urllib3/_version.py | 2 + .../pip/_vendor/urllib3/connection.py | 539 ++ .../pip/_vendor/urllib3/connectionpool.py | 1067 +++ .../pip/_vendor/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 168 bytes .../_appengine_environ.cpython-39.pyc | Bin 0 -> 1388 bytes .../__pycache__/appengine.cpython-39.pyc | Bin 0 -> 8241 bytes .../__pycache__/ntlmpool.cpython-39.pyc | Bin 0 -> 3233 bytes .../__pycache__/pyopenssl.cpython-39.pyc | Bin 0 -> 15500 bytes .../securetransport.cpython-39.pyc | Bin 0 -> 21812 bytes .../contrib/__pycache__/socks.cpython-39.pyc | Bin 0 -> 5604 bytes .../urllib3/contrib/_appengine_environ.py | 36 + .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 185 bytes .../__pycache__/bindings.cpython-39.pyc | Bin 0 -> 10692 bytes .../__pycache__/low_level.cpython-39.pyc | Bin 0 -> 9141 bytes .../contrib/_securetransport/bindings.py | 519 + .../contrib/_securetransport/low_level.py | 396 + .../pip/_vendor/urllib3/contrib/appengine.py | 314 + .../pip/_vendor/urllib3/contrib/ntlmpool.py | 121 + .../pip/_vendor/urllib3/contrib/pyopenssl.py | 509 + .../urllib3/contrib/securetransport.py | 920 ++ .../pip/_vendor/urllib3/contrib/socks.py | 216 + .../pip/_vendor/urllib3/exceptions.py | 323 + .../pip/_vendor/urllib3/fields.py | 274 + .../pip/_vendor/urllib3/filepost.py | 98 + .../pip/_vendor/urllib3/packages/__init__.py | 5 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 282 bytes .../packages/__pycache__/six.cpython-39.pyc | Bin 0 -> 26486 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 179 bytes .../__pycache__/makefile.cpython-39.pyc | Bin 0 -> 1277 bytes .../urllib3/packages/backports/makefile.py | 51 + .../pip/_vendor/urllib3/packages/six.py | 1021 ++ .../packages/ssl_match_hostname/__init__.py | 22 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 519 bytes .../_implementation.cpython-39.pyc | Bin 0 -> 3272 bytes .../ssl_match_hostname/_implementation.py | 160 + .../pip/_vendor/urllib3/poolmanager.py | 536 ++ .../pip/_vendor/urllib3/request.py | 170 + .../pip/_vendor/urllib3/response.py | 821 ++ .../pip/_vendor/urllib3/util/__init__.py | 49 + .../util/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1078 bytes .../__pycache__/connection.cpython-39.pyc | Bin 0 -> 3432 bytes .../util/__pycache__/proxy.cpython-39.pyc | Bin 0 -> 1314 bytes .../util/__pycache__/queue.cpython-39.pyc | Bin 0 -> 1033 bytes .../util/__pycache__/request.cpython-39.pyc | Bin 0 -> 3421 bytes .../util/__pycache__/response.cpython-39.pyc | Bin 0 -> 2318 bytes .../util/__pycache__/retry.cpython-39.pyc | Bin 0 -> 15935 bytes .../util/__pycache__/ssl_.cpython-39.pyc | Bin 0 -> 10996 bytes .../__pycache__/ssltransport.cpython-39.pyc | Bin 0 -> 7484 bytes .../util/__pycache__/timeout.cpython-39.pyc | Bin 0 -> 8916 bytes .../util/__pycache__/url.cpython-39.pyc | Bin 0 -> 10592 bytes .../util/__pycache__/wait.cpython-39.pyc | Bin 0 -> 3101 bytes .../pip/_vendor/urllib3/util/connection.py | 150 + .../pip/_vendor/urllib3/util/proxy.py | 56 + .../pip/_vendor/urllib3/util/queue.py | 22 + .../pip/_vendor/urllib3/util/request.py | 143 + .../pip/_vendor/urllib3/util/response.py | 107 + .../pip/_vendor/urllib3/util/retry.py | 602 ++ .../pip/_vendor/urllib3/util/ssl_.py | 474 + .../pip/_vendor/urllib3/util/ssltransport.py | 221 + .../pip/_vendor/urllib3/util/timeout.py | 268 + .../pip/_vendor/urllib3/util/url.py | 430 + .../pip/_vendor/urllib3/util/wait.py | 153 + .../Lib/site-packages/pip/_vendor/vendor.txt | 22 + .../pip/_vendor/webencodings/__init__.py | 342 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 9692 bytes .../__pycache__/labels.cpython-39.pyc | Bin 0 -> 3806 bytes .../__pycache__/mklabels.cpython-39.pyc | Bin 0 -> 1876 bytes .../__pycache__/tests.cpython-39.pyc | Bin 0 -> 5040 bytes .../__pycache__/x_user_defined.cpython-39.pyc | Bin 0 -> 2636 bytes .../pip/_vendor/webencodings/labels.py | 231 + .../pip/_vendor/webencodings/mklabels.py | 59 + .../pip/_vendor/webencodings/tests.py | 153 + .../_vendor/webencodings/x_user_defined.py | 325 + .../pyvenv3.9/Lib/site-packages/pip/py.typed | 4 + .../site-packages/pkg_resources/__init__.py | 3288 +++++++ .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 100408 bytes .../pkg_resources/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 162 bytes .../__pycache__/appdirs.cpython-39.pyc | Bin 0 -> 20479 bytes .../__pycache__/pyparsing.cpython-39.pyc | Bin 0 -> 201315 bytes .../pkg_resources/_vendor/appdirs.py | 608 ++ .../_vendor/packaging/__about__.py | 27 + .../_vendor/packaging/__init__.py | 26 + .../__pycache__/__about__.cpython-39.pyc | Bin 0 -> 678 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 524 bytes .../__pycache__/_compat.cpython-39.pyc | Bin 0 -> 1122 bytes .../__pycache__/_structures.cpython-39.pyc | Bin 0 -> 2876 bytes .../__pycache__/_typing.cpython-39.pyc | Bin 0 -> 1467 bytes .../__pycache__/markers.cpython-39.pyc | Bin 0 -> 9283 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 0 -> 4060 bytes .../__pycache__/specifiers.cpython-39.pyc | Bin 0 -> 20559 bytes .../packaging/__pycache__/tags.cpython-39.pyc | Bin 0 -> 17238 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 1629 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 13296 bytes .../_vendor/packaging/_compat.py | 38 + .../_vendor/packaging/_structures.py | 86 + .../_vendor/packaging/_typing.py | 48 + .../_vendor/packaging/markers.py | 328 + .../_vendor/packaging/requirements.py | 145 + .../_vendor/packaging/specifiers.py | 863 ++ .../pkg_resources/_vendor/packaging/tags.py | 751 ++ .../pkg_resources/_vendor/packaging/utils.py | 65 + .../_vendor/packaging/version.py | 535 ++ .../pkg_resources/_vendor/pyparsing.py | 5742 +++++++++++ .../pkg_resources/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2851 bytes .../__pycache__/setup.cpython-39.pyc | Bin 0 -> 290 bytes .../data/my-test-package-source/setup.py | 6 + .../pymongo-3.12.1.dist-info/INSTALLER | 1 + .../pymongo-3.12.1.dist-info/LICENSE | 201 + .../pymongo-3.12.1.dist-info/METADATA | 285 + .../pymongo-3.12.1.dist-info/RECORD | 177 + .../pymongo-3.12.1.dist-info/REQUESTED | 0 .../pymongo-3.12.1.dist-info/WHEEL | 5 + .../pymongo-3.12.1.dist-info/top_level.txt | 3 + .../Lib/site-packages/pymongo/__init__.py | 134 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1543 bytes .../__pycache__/_ipaddress.cpython-39.pyc | Bin 0 -> 999 bytes .../__pycache__/aggregation.cpython-39.pyc | Bin 0 -> 7022 bytes .../pymongo/__pycache__/auth.cpython-39.pyc | Bin 0 -> 16298 bytes .../__pycache__/auth_aws.cpython-39.pyc | Bin 0 -> 2541 bytes .../pymongo/__pycache__/bulk.cpython-39.pyc | Bin 0 -> 19323 bytes .../__pycache__/change_stream.cpython-39.pyc | Bin 0 -> 13111 bytes .../__pycache__/client_options.cpython-39.pyc | Bin 0 -> 9180 bytes .../__pycache__/client_session.cpython-39.pyc | Bin 0 -> 34665 bytes .../__pycache__/collation.cpython-39.pyc | Bin 0 -> 6518 bytes .../__pycache__/collection.cpython-39.pyc | Bin 0 -> 127194 bytes .../__pycache__/command_cursor.cpython-39.pyc | Bin 0 -> 10120 bytes .../pymongo/__pycache__/common.cpython-39.pyc | Bin 0 -> 26555 bytes .../compression_support.cpython-39.pyc | Bin 0 -> 4125 bytes .../pymongo/__pycache__/cursor.cpython-39.pyc | Bin 0 -> 38767 bytes .../__pycache__/cursor_manager.cpython-39.pyc | Bin 0 -> 1924 bytes .../pymongo/__pycache__/daemon.cpython-39.pyc | Bin 0 -> 3168 bytes .../__pycache__/database.cpython-39.pyc | Bin 0 -> 64664 bytes .../__pycache__/driver_info.cpython-39.pyc | Bin 0 -> 1342 bytes .../__pycache__/encryption.cpython-39.pyc | Bin 0 -> 20300 bytes .../encryption_options.cpython-39.pyc | Bin 0 -> 7129 bytes .../pymongo/__pycache__/errors.cpython-39.pyc | Bin 0 -> 12479 bytes .../__pycache__/event_loggers.cpython-39.pyc | Bin 0 -> 8999 bytes .../pymongo/__pycache__/hello.cpython-39.pyc | Bin 0 -> 6387 bytes .../__pycache__/hello_compat.cpython-39.pyc | Bin 0 -> 511 bytes .../__pycache__/helpers.cpython-39.pyc | Bin 0 -> 6265 bytes .../__pycache__/ismaster.cpython-39.pyc | Bin 0 -> 705 bytes .../max_staleness_selectors.cpython-39.pyc | Bin 0 -> 2456 bytes .../__pycache__/message.cpython-39.pyc | Bin 0 -> 42695 bytes .../__pycache__/mongo_client.cpython-39.pyc | Bin 0 -> 90695 bytes .../mongo_replica_set_client.cpython-39.pyc | Bin 0 -> 1848 bytes .../__pycache__/monitor.cpython-39.pyc | Bin 0 -> 11569 bytes .../__pycache__/monitoring.cpython-39.pyc | Bin 0 -> 59200 bytes .../__pycache__/monotonic.cpython-39.pyc | Bin 0 -> 459 bytes .../__pycache__/network.cpython-39.pyc | Bin 0 -> 7425 bytes .../__pycache__/ocsp_cache.cpython-39.pyc | Bin 0 -> 2198 bytes .../__pycache__/ocsp_support.cpython-39.pyc | Bin 0 -> 8839 bytes .../__pycache__/operations.cpython-39.pyc | Bin 0 -> 16796 bytes .../periodic_executor.cpython-39.pyc | Bin 0 -> 4285 bytes .../pymongo/__pycache__/pool.cpython-39.pyc | Bin 0 -> 40432 bytes .../pyopenssl_context.cpython-39.pyc | Bin 0 -> 10072 bytes .../__pycache__/read_concern.cpython-39.pyc | Bin 0 -> 2289 bytes .../read_preferences.cpython-39.pyc | Bin 0 -> 18331 bytes .../__pycache__/response.cpython-39.pyc | Bin 0 -> 3715 bytes .../__pycache__/results.cpython-39.pyc | Bin 0 -> 8373 bytes .../__pycache__/saslprep.cpython-39.pyc | Bin 0 -> 2420 bytes .../pymongo/__pycache__/server.cpython-39.pyc | Bin 0 -> 5874 bytes .../__pycache__/server_api.cpython-39.pyc | Bin 0 -> 5553 bytes .../server_description.cpython-39.pyc | Bin 0 -> 8240 bytes .../server_selectors.cpython-39.pyc | Bin 0 -> 5735 bytes .../__pycache__/server_type.cpython-39.pyc | Bin 0 -> 412 bytes .../__pycache__/settings.cpython-39.pyc | Bin 0 -> 4784 bytes .../__pycache__/socket_checker.cpython-39.pyc | Bin 0 -> 2069 bytes .../son_manipulator.cpython-39.pyc | Bin 0 -> 7399 bytes .../__pycache__/srv_resolver.cpython-39.pyc | Bin 0 -> 3669 bytes .../__pycache__/ssl_context.cpython-39.pyc | Bin 0 -> 4110 bytes .../ssl_match_hostname.cpython-39.pyc | Bin 0 -> 2880 bytes .../__pycache__/ssl_support.cpython-39.pyc | Bin 0 -> 4414 bytes .../__pycache__/thread_util.cpython-39.pyc | Bin 0 -> 4238 bytes .../__pycache__/topology.cpython-39.pyc | Bin 0 -> 21866 bytes .../topology_description.cpython-39.pyc | Bin 0 -> 15267 bytes .../__pycache__/uri_parser.cpython-39.pyc | Bin 0 -> 14882 bytes .../__pycache__/write_concern.cpython-39.pyc | Bin 0 -> 4549 bytes .../pymongo/_cmessage.cp39-win_amd64.pyd | Bin 0 -> 31744 bytes .../Lib/site-packages/pymongo/_ipaddress.py | 56 + .../Lib/site-packages/pymongo/aggregation.py | 238 + .../Lib/site-packages/pymongo/auth.py | 677 ++ .../Lib/site-packages/pymongo/auth_aws.py | 85 + .../Lib/site-packages/pymongo/bulk.py | 713 ++ .../site-packages/pymongo/change_stream.py | 410 + .../site-packages/pymongo/client_options.py | 267 + .../site-packages/pymongo/client_session.py | 1045 ++ .../Lib/site-packages/pymongo/collation.py | 225 + .../Lib/site-packages/pymongo/collection.py | 3494 +++++++ .../site-packages/pymongo/command_cursor.py | 329 + .../Lib/site-packages/pymongo/common.py | 982 ++ .../pymongo/compression_support.py | 158 + .../Lib/site-packages/pymongo/cursor.py | 1346 +++ .../site-packages/pymongo/cursor_manager.py | 65 + .../Lib/site-packages/pymongo/daemon.py | 158 + .../Lib/site-packages/pymongo/database.py | 1700 ++++ .../Lib/site-packages/pymongo/driver_info.py | 39 + .../Lib/site-packages/pymongo/encryption.py | 584 ++ .../pymongo/encryption_options.py | 155 + .../Lib/site-packages/pymongo/errors.py | 317 + .../site-packages/pymongo/event_loggers.py | 207 + .../Lib/site-packages/pymongo/hello.py | 199 + .../Lib/site-packages/pymongo/hello_compat.py | 23 + .../Lib/site-packages/pymongo/helpers.py | 287 + .../Lib/site-packages/pymongo/ismaster.py | 30 + .../pymongo/max_staleness_selectors.py | 116 + .../Lib/site-packages/pymongo/message.py | 1778 ++++ .../Lib/site-packages/pymongo/mongo_client.py | 2434 +++++ .../pymongo/mongo_replica_set_client.py | 48 + .../Lib/site-packages/pymongo/monitor.py | 440 + .../Lib/site-packages/pymongo/monitoring.py | 1653 ++++ .../Lib/site-packages/pymongo/monotonic.py | 38 + .../Lib/site-packages/pymongo/network.py | 301 + .../Lib/site-packages/pymongo/ocsp_cache.py | 87 + .../Lib/site-packages/pymongo/ocsp_support.py | 366 + .../Lib/site-packages/pymongo/operations.py | 452 + .../pymongo/periodic_executor.py | 184 + .../Lib/site-packages/pymongo/pool.py | 1524 +++ .../pymongo/pyopenssl_context.py | 324 + .../Lib/site-packages/pymongo/read_concern.py | 76 + .../site-packages/pymongo/read_preferences.py | 537 ++ .../Lib/site-packages/pymongo/response.py | 112 + .../Lib/site-packages/pymongo/results.py | 226 + .../Lib/site-packages/pymongo/saslprep.py | 108 + .../Lib/site-packages/pymongo/server.py | 234 + .../Lib/site-packages/pymongo/server_api.py | 168 + .../pymongo/server_description.py | 258 + .../site-packages/pymongo/server_selectors.py | 156 + .../Lib/site-packages/pymongo/server_type.py | 23 + .../Lib/site-packages/pymongo/settings.py | 148 + .../site-packages/pymongo/socket_checker.py | 101 + .../site-packages/pymongo/son_manipulator.py | 191 + .../Lib/site-packages/pymongo/srv_resolver.py | 123 + .../Lib/site-packages/pymongo/ssl_context.py | 132 + .../pymongo/ssl_match_hostname.py | 132 + .../Lib/site-packages/pymongo/ssl_support.py | 184 + .../Lib/site-packages/pymongo/thread_util.py | 129 + .../Lib/site-packages/pymongo/topology.py | 819 ++ .../pymongo/topology_description.py | 608 ++ .../Lib/site-packages/pymongo/uri_parser.py | 561 ++ .../site-packages/pymongo/write_concern.py | 126 + .../pyoperators-0.3-py3.9.egg-info/PKG-INFO | 120 + .../SOURCES.txt | 22 + .../dependency_links.txt | 1 + .../installed-files.txt | 36 + .../top_level.txt | 1 + .../Lib/site-packages/pyoperators/__init__.py | 34 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1067 bytes .../__pycache__/core.cpython-39.pyc | Bin 0 -> 92928 bytes .../__pycache__/decorators.cpython-39.pyc | Bin 0 -> 3571 bytes .../__pycache__/linear.cpython-39.pyc | Bin 0 -> 19311 bytes .../__pycache__/memory.cpython-39.pyc | Bin 0 -> 4491 bytes .../__pycache__/nonlinear.cpython-39.pyc | Bin 0 -> 6418 bytes .../__pycache__/norms.cpython-39.pyc | Bin 0 -> 1643 bytes .../__pycache__/operators_mpi.cpython-39.pyc | Bin 0 -> 6009 bytes .../__pycache__/operators_pywt.cpython-39.pyc | Bin 0 -> 6328 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 6277 bytes .../Lib/site-packages/pyoperators/core.py | 2906 ++++++ .../site-packages/pyoperators/decorators.py | 100 + .../pyoperators/iterative/__init__.py | 17 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 629 bytes .../__pycache__/algorithms.cpython-39.pyc | Bin 0 -> 14452 bytes .../__pycache__/criterions.cpython-39.pyc | Bin 0 -> 13350 bytes .../iterative/__pycache__/dli.cpython-39.pyc | Bin 0 -> 13054 bytes .../__pycache__/linesearch.cpython-39.pyc | Bin 0 -> 5510 bytes .../__pycache__/optimize.cpython-39.pyc | Bin 0 -> 5831 bytes .../pyoperators/iterative/algorithms.py | 421 + .../pyoperators/iterative/criterions.py | 348 + .../pyoperators/iterative/dli.py | 359 + .../pyoperators/iterative/linesearch.py | 150 + .../pyoperators/iterative/optimize.py | 194 + .../Lib/site-packages/pyoperators/linear.py | 602 ++ .../Lib/site-packages/pyoperators/memory.py | 152 + .../site-packages/pyoperators/nonlinear.py | 182 + .../Lib/site-packages/pyoperators/norms.py | 34 + .../pyoperators/operators_mpi.py | 194 + .../pyoperators/operators_pywt.py | 146 + .../Lib/site-packages/pyoperators/utils.py | 189 + .../pyspellchecker-0.6.2.dist-info/INSTALLER | 1 + .../pyspellchecker-0.6.2.dist-info/LICENSE | 21 + .../pyspellchecker-0.6.2.dist-info/METADATA | 225 + .../pyspellchecker-0.6.2.dist-info/RECORD | 21 + .../pyspellchecker-0.6.2.dist-info/REQUESTED | 0 .../pyspellchecker-0.6.2.dist-info/WHEEL | 5 + .../top_level.txt | 1 + .../ranking-0.3.2.dist-info/INSTALLER | 1 + .../ranking-0.3.2.dist-info/LICENSE | 31 + .../ranking-0.3.2.dist-info/METADATA | 62 + .../ranking-0.3.2.dist-info/RECORD | 14 + .../ranking-0.3.2.dist-info/REQUESTED | 0 .../ranking-0.3.2.dist-info/WHEEL | 5 + .../ranking-0.3.2.dist-info/top_level.txt | 1 + .../site-packages/ranking.egg-info/PKG-INFO | 60 + .../ranking.egg-info/SOURCES.txt | 10 + .../ranking.egg-info/dependency_links.txt | 1 + .../ranking.egg-info/top_level.txt | 1 + .../pyvenv3.9/Lib/site-packages/ranking.py | 163 + .../regex-2021.10.23.dist-info/INSTALLER | 1 + .../regex-2021.10.23.dist-info/LICENSE.txt | 208 + .../regex-2021.10.23.dist-info/METADATA | 1094 +++ .../regex-2021.10.23.dist-info/RECORD | 15 + .../regex-2021.10.23.dist-info/WHEEL | 5 + .../regex-2021.10.23.dist-info/top_level.txt | 1 + .../Lib/site-packages/regex/__init__.py | 3 + .../regex/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 208 bytes .../__pycache__/_regex_core.cpython-39.pyc | Bin 0 -> 111981 bytes .../regex/__pycache__/regex.cpython-39.pyc | Bin 0 -> 25412 bytes .../__pycache__/test_regex.cpython-39.pyc | Bin 0 -> 135956 bytes .../regex/_regex.cp39-win_amd64.pyd | Bin 0 -> 681984 bytes .../Lib/site-packages/regex/_regex_core.py | 4463 +++++++++ .../Lib/site-packages/regex/regex.py | 740 ++ .../Lib/site-packages/regex/test_regex.py | 4438 +++++++++ .../requests-2.26.0.dist-info/INSTALLER | 1 + .../requests-2.26.0.dist-info/LICENSE | 175 + .../requests-2.26.0.dist-info/METADATA | 120 + .../requests-2.26.0.dist-info/RECORD | 43 + .../requests-2.26.0.dist-info/REQUESTED | 0 .../requests-2.26.0.dist-info/WHEEL | 6 + .../requests-2.26.0.dist-info/top_level.txt | 1 + .../Lib/site-packages/requests/__init__.py | 152 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3834 bytes .../__pycache__/__version__.cpython-39.pyc | Bin 0 -> 512 bytes .../_internal_utils.cpython-39.pyc | Bin 0 -> 1259 bytes .../__pycache__/adapters.cpython-39.pyc | Bin 0 -> 16858 bytes .../requests/__pycache__/api.cpython-39.pyc | Bin 0 -> 6676 bytes .../requests/__pycache__/auth.cpython-39.pyc | Bin 0 -> 8288 bytes .../requests/__pycache__/certs.cpython-39.pyc | Bin 0 -> 578 bytes .../__pycache__/compat.cpython-39.pyc | Bin 0 -> 1668 bytes .../__pycache__/cookies.cpython-39.pyc | Bin 0 -> 18779 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 5350 bytes .../requests/__pycache__/help.cpython-39.pyc | Bin 0 -> 2830 bytes .../requests/__pycache__/hooks.cpython-39.pyc | Bin 0 -> 947 bytes .../__pycache__/models.cpython-39.pyc | Bin 0 -> 24355 bytes .../__pycache__/packages.cpython-39.pyc | Bin 0 -> 654 bytes .../__pycache__/sessions.cpython-39.pyc | Bin 0 -> 19814 bytes .../__pycache__/status_codes.cpython-39.pyc | Bin 0 -> 4196 bytes .../__pycache__/structures.cpython-39.pyc | Bin 0 -> 4417 bytes .../requests/__pycache__/utils.cpython-39.pyc | Bin 0 -> 23269 bytes .../Lib/site-packages/requests/__version__.py | 14 + .../site-packages/requests/_internal_utils.py | 42 + .../Lib/site-packages/requests/adapters.py | 533 ++ .../Lib/site-packages/requests/api.py | 159 + .../Lib/site-packages/requests/auth.py | 305 + .../Lib/site-packages/requests/certs.py | 18 + .../Lib/site-packages/requests/compat.py | 75 + .../Lib/site-packages/requests/cookies.py | 549 ++ .../Lib/site-packages/requests/exceptions.py | 127 + .../Lib/site-packages/requests/help.py | 135 + .../Lib/site-packages/requests/hooks.py | 34 + .../Lib/site-packages/requests/models.py | 966 ++ .../Lib/site-packages/requests/packages.py | 26 + .../Lib/site-packages/requests/sessions.py | 781 ++ .../site-packages/requests/status_codes.py | 123 + .../Lib/site-packages/requests/structures.py | 105 + .../Lib/site-packages/requests/utils.py | 1013 ++ .../setuptools-56.0.0.dist-info/INSTALLER | 1 + .../setuptools-56.0.0.dist-info/LICENSE | 19 + .../setuptools-56.0.0.dist-info/METADATA | 114 + .../setuptools-56.0.0.dist-info/RECORD | 295 + .../setuptools-56.0.0.dist-info/REQUESTED | 0 .../setuptools-56.0.0.dist-info/WHEEL | 5 + .../dependency_links.txt | 2 + .../entry_points.txt | 60 + .../setuptools-56.0.0.dist-info/top_level.txt | 3 + .../Lib/site-packages/setuptools/__init__.py | 241 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 8595 bytes .../_deprecation_warning.cpython-39.pyc | Bin 0 -> 521 bytes .../__pycache__/_imp.cpython-39.pyc | Bin 0 -> 2056 bytes .../__pycache__/archive_util.cpython-39.pyc | Bin 0 -> 5785 bytes .../__pycache__/build_meta.cpython-39.pyc | Bin 0 -> 9044 bytes .../__pycache__/config.cpython-39.pyc | Bin 0 -> 19819 bytes .../__pycache__/dep_util.cpython-39.pyc | Bin 0 -> 828 bytes .../__pycache__/depends.cpython-39.pyc | Bin 0 -> 5220 bytes .../__pycache__/dist.cpython-39.pyc | Bin 0 -> 33303 bytes .../__pycache__/errors.cpython-39.pyc | Bin 0 -> 821 bytes .../__pycache__/extension.cpython-39.pyc | Bin 0 -> 1915 bytes .../__pycache__/glob.cpython-39.pyc | Bin 0 -> 3665 bytes .../__pycache__/installer.cpython-39.pyc | Bin 0 -> 2742 bytes .../__pycache__/launch.cpython-39.pyc | Bin 0 -> 872 bytes .../__pycache__/lib2to3_ex.cpython-39.pyc | Bin 0 -> 2674 bytes .../__pycache__/monkey.cpython-39.pyc | Bin 0 -> 4584 bytes .../__pycache__/msvc.cpython-39.pyc | Bin 0 -> 43241 bytes .../__pycache__/namespaces.cpython-39.pyc | Bin 0 -> 3571 bytes .../__pycache__/package_index.cpython-39.pyc | Bin 0 -> 33065 bytes .../__pycache__/py34compat.cpython-39.pyc | Bin 0 -> 451 bytes .../__pycache__/sandbox.cpython-39.pyc | Bin 0 -> 15745 bytes .../__pycache__/ssl_support.cpython-39.pyc | Bin 0 -> 6832 bytes .../__pycache__/unicode_utils.cpython-39.pyc | Bin 0 -> 1085 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 295 bytes .../__pycache__/wheel.cpython-39.pyc | Bin 0 -> 7251 bytes .../windows_support.cpython-39.pyc | Bin 0 -> 994 bytes .../setuptools/_deprecation_warning.py | 7 + .../setuptools/_distutils/__init__.py | 15 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 429 bytes .../__pycache__/_msvccompiler.cpython-39.pyc | Bin 0 -> 13784 bytes .../__pycache__/archive_util.cpython-39.pyc | Bin 0 -> 6616 bytes .../__pycache__/bcppcompiler.cpython-39.pyc | Bin 0 -> 6527 bytes .../__pycache__/ccompiler.cpython-39.pyc | Bin 0 -> 33232 bytes .../_distutils/__pycache__/cmd.cpython-39.pyc | Bin 0 -> 13955 bytes .../__pycache__/config.cpython-39.pyc | Bin 0 -> 3558 bytes .../__pycache__/core.cpython-39.pyc | Bin 0 -> 6683 bytes .../cygwinccompiler.cpython-39.pyc | Bin 0 -> 8532 bytes .../__pycache__/debug.cpython-39.pyc | Bin 0 -> 225 bytes .../__pycache__/dep_util.cpython-39.pyc | Bin 0 -> 2745 bytes .../__pycache__/dir_util.cpython-39.pyc | Bin 0 -> 5846 bytes .../__pycache__/dist.cpython-39.pyc | Bin 0 -> 34416 bytes .../__pycache__/errors.cpython-39.pyc | Bin 0 -> 5281 bytes .../__pycache__/extension.cpython-39.pyc | Bin 0 -> 6946 bytes .../__pycache__/fancy_getopt.cpython-39.pyc | Bin 0 -> 10654 bytes .../__pycache__/file_util.cpython-39.pyc | Bin 0 -> 6012 bytes .../__pycache__/filelist.cpython-39.pyc | Bin 0 -> 9864 bytes .../_distutils/__pycache__/log.cpython-39.pyc | Bin 0 -> 2344 bytes .../__pycache__/msvc9compiler.cpython-39.pyc | Bin 0 -> 17541 bytes .../__pycache__/msvccompiler.cpython-39.pyc | Bin 0 -> 14736 bytes .../__pycache__/py35compat.cpython-39.pyc | Bin 0 -> 601 bytes .../__pycache__/py38compat.cpython-39.pyc | Bin 0 -> 396 bytes .../__pycache__/spawn.cpython-39.pyc | Bin 0 -> 3397 bytes .../__pycache__/sysconfig.cpython-39.pyc | Bin 0 -> 12378 bytes .../__pycache__/text_file.cpython-39.pyc | Bin 0 -> 8470 bytes .../__pycache__/unixccompiler.cpython-39.pyc | Bin 0 -> 6631 bytes .../__pycache__/util.cpython-39.pyc | Bin 0 -> 15664 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 7370 bytes .../versionpredicate.cpython-39.pyc | Bin 0 -> 5154 bytes .../setuptools/_distutils/_msvccompiler.py | 561 ++ .../setuptools/_distutils/archive_util.py | 256 + .../setuptools/_distutils/bcppcompiler.py | 393 + .../setuptools/_distutils/ccompiler.py | 1116 +++ .../setuptools/_distutils/cmd.py | 403 + .../setuptools/_distutils/command/__init__.py | 31 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 504 bytes .../command/__pycache__/bdist.cpython-39.pyc | Bin 0 -> 3634 bytes .../__pycache__/bdist_dumb.cpython-39.pyc | Bin 0 -> 3617 bytes .../__pycache__/bdist_msi.cpython-39.pyc | Bin 0 -> 19799 bytes .../__pycache__/bdist_rpm.cpython-39.pyc | Bin 0 -> 12254 bytes .../__pycache__/bdist_wininst.cpython-39.pyc | Bin 0 -> 8574 bytes .../command/__pycache__/build.cpython-39.pyc | Bin 0 -> 3910 bytes .../__pycache__/build_clib.cpython-39.pyc | Bin 0 -> 4829 bytes .../__pycache__/build_ext.cpython-39.pyc | Bin 0 -> 16278 bytes .../__pycache__/build_py.cpython-39.pyc | Bin 0 -> 10462 bytes .../__pycache__/build_scripts.cpython-39.pyc | Bin 0 -> 4359 bytes .../command/__pycache__/check.cpython-39.pyc | Bin 0 -> 4938 bytes .../command/__pycache__/clean.cpython-39.pyc | Bin 0 -> 2111 bytes .../command/__pycache__/config.cpython-39.pyc | Bin 0 -> 10241 bytes .../__pycache__/install.cpython-39.pyc | Bin 0 -> 13828 bytes .../__pycache__/install_data.cpython-39.pyc | Bin 0 -> 2314 bytes .../install_egg_info.cpython-39.pyc | Bin 0 -> 3049 bytes .../install_headers.cpython-39.pyc | Bin 0 -> 1739 bytes .../__pycache__/install_lib.cpython-39.pyc | Bin 0 -> 5111 bytes .../install_scripts.cpython-39.pyc | Bin 0 -> 2162 bytes .../__pycache__/py37compat.cpython-39.pyc | Bin 0 -> 1005 bytes .../__pycache__/register.cpython-39.pyc | Bin 0 -> 8482 bytes .../command/__pycache__/sdist.cpython-39.pyc | Bin 0 -> 14509 bytes .../command/__pycache__/upload.cpython-39.pyc | Bin 0 -> 5232 bytes .../setuptools/_distutils/command/bdist.py | 143 + .../_distutils/command/bdist_dumb.py | 123 + .../_distutils/command/bdist_msi.py | 749 ++ .../_distutils/command/bdist_rpm.py | 579 ++ .../_distutils/command/bdist_wininst.py | 377 + .../setuptools/_distutils/command/build.py | 157 + .../_distutils/command/build_clib.py | 209 + .../_distutils/command/build_ext.py | 755 ++ .../setuptools/_distutils/command/build_py.py | 416 + .../_distutils/command/build_scripts.py | 160 + .../setuptools/_distutils/command/check.py | 148 + .../setuptools/_distutils/command/clean.py | 76 + .../setuptools/_distutils/command/config.py | 344 + .../setuptools/_distutils/command/install.py | 677 ++ .../_distutils/command/install_data.py | 79 + .../_distutils/command/install_egg_info.py | 77 + .../_distutils/command/install_headers.py | 47 + .../_distutils/command/install_lib.py | 217 + .../_distutils/command/install_scripts.py | 60 + .../_distutils/command/py37compat.py | 30 + .../setuptools/_distutils/command/register.py | 304 + .../setuptools/_distutils/command/sdist.py | 494 + .../setuptools/_distutils/command/upload.py | 214 + .../setuptools/_distutils/config.py | 130 + .../setuptools/_distutils/core.py | 234 + .../setuptools/_distutils/cygwinccompiler.py | 403 + .../setuptools/_distutils/debug.py | 5 + .../setuptools/_distutils/dep_util.py | 92 + .../setuptools/_distutils/dir_util.py | 210 + .../setuptools/_distutils/dist.py | 1257 +++ .../setuptools/_distutils/errors.py | 97 + .../setuptools/_distutils/extension.py | 240 + .../setuptools/_distutils/fancy_getopt.py | 457 + .../setuptools/_distutils/file_util.py | 238 + .../setuptools/_distutils/filelist.py | 327 + .../setuptools/_distutils/log.py | 77 + .../setuptools/_distutils/msvc9compiler.py | 788 ++ .../setuptools/_distutils/msvccompiler.py | 643 ++ .../setuptools/_distutils/py35compat.py | 19 + .../setuptools/_distutils/py38compat.py | 7 + .../setuptools/_distutils/spawn.py | 125 + .../setuptools/_distutils/sysconfig.py | 573 ++ .../setuptools/_distutils/text_file.py | 286 + .../setuptools/_distutils/unixccompiler.py | 328 + .../setuptools/_distutils/util.py | 561 ++ .../setuptools/_distutils/version.py | 347 + .../setuptools/_distutils/versionpredicate.py | 166 + .../Lib/site-packages/setuptools/_imp.py | 82 + .../setuptools/_vendor/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 159 bytes .../__pycache__/ordered_set.cpython-39.pyc | Bin 0 -> 16353 bytes .../__pycache__/pyparsing.cpython-39.pyc | Bin 0 -> 201312 bytes .../setuptools/_vendor/ordered_set.py | 488 + .../setuptools/_vendor/packaging/__about__.py | 27 + .../setuptools/_vendor/packaging/__init__.py | 26 + .../__pycache__/__about__.cpython-39.pyc | Bin 0 -> 675 bytes .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 521 bytes .../__pycache__/_compat.cpython-39.pyc | Bin 0 -> 1119 bytes .../__pycache__/_structures.cpython-39.pyc | Bin 0 -> 2873 bytes .../__pycache__/_typing.cpython-39.pyc | Bin 0 -> 1464 bytes .../__pycache__/markers.cpython-39.pyc | Bin 0 -> 9277 bytes .../__pycache__/requirements.cpython-39.pyc | Bin 0 -> 4054 bytes .../__pycache__/specifiers.cpython-39.pyc | Bin 0 -> 20556 bytes .../packaging/__pycache__/tags.cpython-39.pyc | Bin 0 -> 17235 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 1626 bytes .../__pycache__/version.cpython-39.pyc | Bin 0 -> 13293 bytes .../setuptools/_vendor/packaging/_compat.py | 38 + .../_vendor/packaging/_structures.py | 86 + .../setuptools/_vendor/packaging/_typing.py | 48 + .../setuptools/_vendor/packaging/markers.py | 328 + .../_vendor/packaging/requirements.py | 145 + .../_vendor/packaging/specifiers.py | 863 ++ .../setuptools/_vendor/packaging/tags.py | 751 ++ .../setuptools/_vendor/packaging/utils.py | 65 + .../setuptools/_vendor/packaging/version.py | 535 ++ .../setuptools/_vendor/pyparsing.py | 5742 +++++++++++ .../site-packages/setuptools/archive_util.py | 205 + .../site-packages/setuptools/build_meta.py | 281 + .../Lib/site-packages/setuptools/cli-32.exe | Bin 0 -> 65536 bytes .../Lib/site-packages/setuptools/cli-64.exe | Bin 0 -> 74752 bytes .../Lib/site-packages/setuptools/cli.exe | Bin 0 -> 65536 bytes .../setuptools/command/__init__.py | 17 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 624 bytes .../command/__pycache__/alias.cpython-39.pyc | Bin 0 -> 2342 bytes .../__pycache__/bdist_egg.cpython-39.pyc | Bin 0 -> 13008 bytes .../__pycache__/bdist_rpm.cpython-39.pyc | Bin 0 -> 1328 bytes .../__pycache__/build_clib.cpython-39.pyc | Bin 0 -> 2439 bytes .../__pycache__/build_ext.cpython-39.pyc | Bin 0 -> 9712 bytes .../__pycache__/build_py.cpython-39.pyc | Bin 0 -> 8666 bytes .../__pycache__/develop.cpython-39.pyc | Bin 0 -> 6427 bytes .../__pycache__/dist_info.cpython-39.pyc | Bin 0 -> 1366 bytes .../__pycache__/easy_install.cpython-39.pyc | Bin 0 -> 63523 bytes .../__pycache__/egg_info.cpython-39.pyc | Bin 0 -> 21683 bytes .../__pycache__/install.cpython-39.pyc | Bin 0 -> 4007 bytes .../install_egg_info.cpython-39.pyc | Bin 0 -> 2398 bytes .../__pycache__/install_lib.cpython-39.pyc | Bin 0 -> 4105 bytes .../install_scripts.cpython-39.pyc | Bin 0 -> 2393 bytes .../__pycache__/py36compat.cpython-39.pyc | Bin 0 -> 4560 bytes .../__pycache__/register.cpython-39.pyc | Bin 0 -> 816 bytes .../command/__pycache__/rotate.cpython-39.pyc | Bin 0 -> 2475 bytes .../__pycache__/saveopts.cpython-39.pyc | Bin 0 -> 894 bytes .../command/__pycache__/sdist.cpython-39.pyc | Bin 0 -> 7594 bytes .../command/__pycache__/setopt.cpython-39.pyc | Bin 0 -> 4506 bytes .../command/__pycache__/test.cpython-39.pyc | Bin 0 -> 8469 bytes .../command/__pycache__/upload.cpython-39.pyc | Bin 0 -> 789 bytes .../__pycache__/upload_docs.cpython-39.pyc | Bin 0 -> 6132 bytes .../site-packages/setuptools/command/alias.py | 78 + .../setuptools/command/bdist_egg.py | 456 + .../setuptools/command/bdist_rpm.py | 31 + .../setuptools/command/build_clib.py | 101 + .../setuptools/command/build_ext.py | 322 + .../setuptools/command/build_py.py | 270 + .../setuptools/command/develop.py | 216 + .../setuptools/command/dist_info.py | 36 + .../setuptools/command/easy_install.py | 2290 +++++ .../setuptools/command/egg_info.py | 727 ++ .../setuptools/command/install.py | 125 + .../setuptools/command/install_egg_info.py | 62 + .../setuptools/command/install_lib.py | 122 + .../setuptools/command/install_scripts.py | 69 + .../setuptools/command/launcher manifest.xml | 15 + .../setuptools/command/py36compat.py | 134 + .../setuptools/command/register.py | 18 + .../setuptools/command/rotate.py | 64 + .../setuptools/command/saveopts.py | 22 + .../site-packages/setuptools/command/sdist.py | 235 + .../setuptools/command/setopt.py | 148 + .../site-packages/setuptools/command/test.py | 274 + .../setuptools/command/upload.py | 17 + .../setuptools/command/upload_docs.py | 202 + .../Lib/site-packages/setuptools/config.py | 710 ++ .../Lib/site-packages/setuptools/dep_util.py | 25 + .../Lib/site-packages/setuptools/depends.py | 175 + .../Lib/site-packages/setuptools/dist.py | 1057 ++ .../Lib/site-packages/setuptools/errors.py | 16 + .../Lib/site-packages/setuptools/extension.py | 55 + .../setuptools/extern/__init__.py | 73 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2874 bytes .../Lib/site-packages/setuptools/glob.py | 167 + .../Lib/site-packages/setuptools/gui-32.exe | Bin 0 -> 65536 bytes .../Lib/site-packages/setuptools/gui-64.exe | Bin 0 -> 75264 bytes .../Lib/site-packages/setuptools/gui.exe | Bin 0 -> 65536 bytes .../Lib/site-packages/setuptools/installer.py | 97 + .../Lib/site-packages/setuptools/launch.py | 36 + .../site-packages/setuptools/lib2to3_ex.py | 68 + .../Lib/site-packages/setuptools/monkey.py | 177 + .../Lib/site-packages/setuptools/msvc.py | 1826 ++++ .../site-packages/setuptools/namespaces.py | 107 + .../site-packages/setuptools/package_index.py | 1145 +++ .../site-packages/setuptools/py34compat.py | 13 + .../Lib/site-packages/setuptools/sandbox.py | 496 + .../setuptools/script (dev).tmpl | 6 + .../Lib/site-packages/setuptools/script.tmpl | 3 + .../site-packages/setuptools/ssl_support.py | 266 + .../site-packages/setuptools/unicode_utils.py | 42 + .../Lib/site-packages/setuptools/version.py | 6 + .../Lib/site-packages/setuptools/wheel.py | 213 + .../setuptools/windows_support.py | 29 + .../soupsieve-2.2.1.dist-info/INSTALLER | 1 + .../soupsieve-2.2.1.dist-info/LICENSE.md | 21 + .../soupsieve-2.2.1.dist-info/METADATA | 124 + .../soupsieve-2.2.1.dist-info/RECORD | 18 + .../soupsieve-2.2.1.dist-info/WHEEL | 5 + .../soupsieve-2.2.1.dist-info/top_level.txt | 1 + .../Lib/site-packages/soupsieve/__init__.py | 111 + .../Lib/site-packages/soupsieve/__meta__.py | 192 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3643 bytes .../__pycache__/__meta__.cpython-39.pyc | Bin 0 -> 5752 bytes .../__pycache__/css_match.cpython-39.pyc | Bin 0 -> 34003 bytes .../__pycache__/css_parser.cpython-39.pyc | Bin 0 -> 26841 bytes .../__pycache__/css_types.cpython-39.pyc | Bin 0 -> 10597 bytes .../soupsieve/__pycache__/util.cpython-39.pyc | Bin 0 -> 2840 bytes .../Lib/site-packages/soupsieve/css_match.py | 1534 +++ .../Lib/site-packages/soupsieve/css_parser.py | 1209 +++ .../Lib/site-packages/soupsieve/css_types.py | 344 + .../Lib/site-packages/soupsieve/util.py | 110 + .../site-packages/spellchecker/__init__.py | 15 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 488 bytes .../__pycache__/info.cpython-39.pyc | Bin 0 -> 470 bytes .../__pycache__/spellchecker.cpython-39.pyc | Bin 0 -> 22217 bytes .../__pycache__/utils.cpython-39.pyc | Bin 0 -> 5015 bytes .../Lib/site-packages/spellchecker/info.py | 11 + .../spellchecker/resources/de.json.gz | Bin 0 -> 191669 bytes .../spellchecker/resources/en.json.gz | Bin 0 -> 588917 bytes .../spellchecker/resources/es.json.gz | Bin 0 -> 897316 bytes .../spellchecker/resources/fr.json.gz | Bin 0 -> 407058 bytes .../spellchecker/resources/pt.json.gz | Bin 0 -> 407495 bytes .../spellchecker/resources/ru.json.gz | Bin 0 -> 234064 bytes .../spellchecker/spellchecker.py | 565 ++ .../Lib/site-packages/spellchecker/utils.py | 138 + .../tqdm-4.62.3.dist-info/INSTALLER | 1 + .../tqdm-4.62.3.dist-info/LICENCE | 49 + .../tqdm-4.62.3.dist-info/METADATA | 1585 +++ .../tqdm-4.62.3.dist-info/RECORD | 72 + .../site-packages/tqdm-4.62.3.dist-info/WHEEL | 6 + .../tqdm-4.62.3.dist-info/entry_points.txt | 3 + .../tqdm-4.62.3.dist-info/top_level.txt | 1 + .../Lib/site-packages/tqdm/__init__.py | 41 + .../Lib/site-packages/tqdm/__main__.py | 3 + .../tqdm/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1581 bytes .../tqdm/__pycache__/__main__.cpython-39.pyc | Bin 0 -> 185 bytes .../tqdm/__pycache__/_dist_ver.cpython-39.pyc | Bin 0 -> 168 bytes .../tqdm/__pycache__/_main.cpython-39.pyc | Bin 0 -> 419 bytes .../tqdm/__pycache__/_monitor.cpython-39.pyc | Bin 0 -> 2772 bytes .../tqdm/__pycache__/_tqdm.cpython-39.pyc | Bin 0 -> 414 bytes .../tqdm/__pycache__/_tqdm_gui.cpython-39.pyc | Bin 0 -> 427 bytes .../__pycache__/_tqdm_notebook.cpython-39.pyc | Bin 0 -> 447 bytes .../__pycache__/_tqdm_pandas.cpython-39.pyc | Bin 0 -> 928 bytes .../tqdm/__pycache__/_utils.cpython-39.pyc | Bin 0 -> 875 bytes .../tqdm/__pycache__/asyncio.cpython-39.pyc | Bin 0 -> 3332 bytes .../tqdm/__pycache__/auto.cpython-39.pyc | Bin 0 -> 1229 bytes .../__pycache__/autonotebook.cpython-39.pyc | Bin 0 -> 906 bytes .../tqdm/__pycache__/cli.cpython-39.pyc | Bin 0 -> 8902 bytes .../tqdm/__pycache__/dask.cpython-39.pyc | Bin 0 -> 2101 bytes .../tqdm/__pycache__/gui.cpython-39.pyc | Bin 0 -> 4683 bytes .../tqdm/__pycache__/keras.cpython-39.pyc | Bin 0 -> 4956 bytes .../tqdm/__pycache__/notebook.cpython-39.pyc | Bin 0 -> 7489 bytes .../tqdm/__pycache__/rich.cpython-39.pyc | Bin 0 -> 5030 bytes .../tqdm/__pycache__/std.cpython-39.pyc | Bin 0 -> 45181 bytes .../tqdm/__pycache__/tk.cpython-39.pyc | Bin 0 -> 6330 bytes .../tqdm/__pycache__/utils.cpython-39.pyc | Bin 0 -> 11747 bytes .../tqdm/__pycache__/version.cpython-39.pyc | Bin 0 -> 479 bytes .../Lib/site-packages/tqdm/_dist_ver.py | 1 + .../pyvenv3.9/Lib/site-packages/tqdm/_main.py | 9 + .../Lib/site-packages/tqdm/_monitor.py | 95 + .../pyvenv3.9/Lib/site-packages/tqdm/_tqdm.py | 9 + .../Lib/site-packages/tqdm/_tqdm_gui.py | 9 + .../Lib/site-packages/tqdm/_tqdm_notebook.py | 9 + .../Lib/site-packages/tqdm/_tqdm_pandas.py | 24 + .../Lib/site-packages/tqdm/_utils.py | 12 + .../Lib/site-packages/tqdm/asyncio.py | 93 + .../pyvenv3.9/Lib/site-packages/tqdm/auto.py | 44 + .../Lib/site-packages/tqdm/autonotebook.py | 28 + .../pyvenv3.9/Lib/site-packages/tqdm/cli.py | 308 + .../Lib/site-packages/tqdm/completion.sh | 19 + .../site-packages/tqdm/contrib/__init__.py | 98 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 3105 bytes .../contrib/__pycache__/bells.cpython-39.pyc | Bin 0 -> 924 bytes .../__pycache__/concurrent.cpython-39.pyc | Bin 0 -> 4291 bytes .../__pycache__/discord.cpython-39.pyc | Bin 0 -> 4397 bytes .../__pycache__/itertools.cpython-39.pyc | Bin 0 -> 958 bytes .../__pycache__/logging.cpython-39.pyc | Bin 0 -> 3889 bytes .../__pycache__/telegram.cpython-39.pyc | Bin 0 -> 5409 bytes .../__pycache__/utils_worker.cpython-39.pyc | Bin 0 -> 1505 bytes .../Lib/site-packages/tqdm/contrib/bells.py | 24 + .../site-packages/tqdm/contrib/concurrent.py | 130 + .../Lib/site-packages/tqdm/contrib/discord.py | 121 + .../site-packages/tqdm/contrib/itertools.py | 36 + .../Lib/site-packages/tqdm/contrib/logging.py | 128 + .../site-packages/tqdm/contrib/telegram.py | 159 + .../tqdm/contrib/utils_worker.py | 40 + .../pyvenv3.9/Lib/site-packages/tqdm/dask.py | 46 + .../pyvenv3.9/Lib/site-packages/tqdm/gui.py | 191 + .../pyvenv3.9/Lib/site-packages/tqdm/keras.py | 124 + .../Lib/site-packages/tqdm/notebook.py | 327 + .../pyvenv3.9/Lib/site-packages/tqdm/rich.py | 152 + .../pyvenv3.9/Lib/site-packages/tqdm/std.py | 1526 +++ .../pyvenv3.9/Lib/site-packages/tqdm/tk.py | 207 + .../pyvenv3.9/Lib/site-packages/tqdm/tqdm.1 | 316 + .../pyvenv3.9/Lib/site-packages/tqdm/utils.py | 354 + .../Lib/site-packages/tqdm/version.py | 9 + .../urllib3-1.26.7.dist-info/INSTALLER | 1 + .../urllib3-1.26.7.dist-info/LICENSE.txt | 21 + .../urllib3-1.26.7.dist-info/METADATA | 1396 +++ .../urllib3-1.26.7.dist-info/RECORD | 84 + .../urllib3-1.26.7.dist-info/WHEEL | 6 + .../urllib3-1.26.7.dist-info/top_level.txt | 1 + .../Lib/site-packages/urllib3/__init__.py | 85 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 2146 bytes .../__pycache__/_collections.cpython-39.pyc | Bin 0 -> 10741 bytes .../__pycache__/_version.cpython-39.pyc | Bin 0 -> 170 bytes .../__pycache__/connection.cpython-39.pyc | Bin 0 -> 13639 bytes .../__pycache__/connectionpool.cpython-39.pyc | Bin 0 -> 24666 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 11603 bytes .../urllib3/__pycache__/fields.cpython-39.pyc | Bin 0 -> 8118 bytes .../__pycache__/filepost.cpython-39.pyc | Bin 0 -> 2719 bytes .../__pycache__/poolmanager.cpython-39.pyc | Bin 0 -> 15121 bytes .../__pycache__/request.cpython-39.pyc | Bin 0 -> 5582 bytes .../__pycache__/response.cpython-39.pyc | Bin 0 -> 20793 bytes .../Lib/site-packages/urllib3/_collections.py | 337 + .../Lib/site-packages/urllib3/_version.py | 2 + .../Lib/site-packages/urllib3/connection.py | 569 ++ .../site-packages/urllib3/connectionpool.py | 1078 +++ .../site-packages/urllib3/contrib/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 156 bytes .../_appengine_environ.cpython-39.pyc | Bin 0 -> 1376 bytes .../__pycache__/appengine.cpython-39.pyc | Bin 0 -> 8205 bytes .../__pycache__/ntlmpool.cpython-39.pyc | Bin 0 -> 3583 bytes .../__pycache__/pyopenssl.cpython-39.pyc | Bin 0 -> 15527 bytes .../securetransport.cpython-39.pyc | Bin 0 -> 21843 bytes .../contrib/__pycache__/socks.cpython-39.pyc | Bin 0 -> 5592 bytes .../urllib3/contrib/_appengine_environ.py | 36 + .../contrib/_securetransport/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 173 bytes .../__pycache__/bindings.cpython-39.pyc | Bin 0 -> 10668 bytes .../__pycache__/low_level.cpython-39.pyc | Bin 0 -> 9133 bytes .../contrib/_securetransport/bindings.py | 519 + .../contrib/_securetransport/low_level.py | 397 + .../urllib3/contrib/appengine.py | 314 + .../site-packages/urllib3/contrib/ntlmpool.py | 130 + .../urllib3/contrib/pyopenssl.py | 511 + .../urllib3/contrib/securetransport.py | 922 ++ .../site-packages/urllib3/contrib/socks.py | 216 + .../Lib/site-packages/urllib3/exceptions.py | 323 + .../Lib/site-packages/urllib3/fields.py | 274 + .../Lib/site-packages/urllib3/filepost.py | 98 + .../urllib3/packages/__init__.py | 5 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 270 bytes .../packages/__pycache__/six.cpython-39.pyc | Bin 0 -> 27540 bytes .../urllib3/packages/backports/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 167 bytes .../__pycache__/makefile.cpython-39.pyc | Bin 0 -> 1265 bytes .../urllib3/packages/backports/makefile.py | 51 + .../Lib/site-packages/urllib3/packages/six.py | 1077 +++ .../packages/ssl_match_hostname/__init__.py | 24 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 529 bytes .../_implementation.cpython-39.pyc | Bin 0 -> 3260 bytes .../ssl_match_hostname/_implementation.py | 160 + .../Lib/site-packages/urllib3/poolmanager.py | 536 ++ .../Lib/site-packages/urllib3/request.py | 170 + .../Lib/site-packages/urllib3/response.py | 821 ++ .../site-packages/urllib3/util/__init__.py | 49 + .../util/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 1066 bytes .../__pycache__/connection.cpython-39.pyc | Bin 0 -> 3406 bytes .../util/__pycache__/proxy.cpython-39.pyc | Bin 0 -> 1302 bytes .../util/__pycache__/queue.cpython-39.pyc | Bin 0 -> 1021 bytes .../util/__pycache__/request.cpython-39.pyc | Bin 0 -> 3409 bytes .../util/__pycache__/response.cpython-39.pyc | Bin 0 -> 2306 bytes .../util/__pycache__/retry.cpython-39.pyc | Bin 0 -> 15793 bytes .../util/__pycache__/ssl_.cpython-39.pyc | Bin 0 -> 11278 bytes .../__pycache__/ssltransport.cpython-39.pyc | Bin 0 -> 7447 bytes .../util/__pycache__/timeout.cpython-39.pyc | Bin 0 -> 8904 bytes .../util/__pycache__/url.cpython-39.pyc | Bin 0 -> 10605 bytes .../util/__pycache__/wait.cpython-39.pyc | Bin 0 -> 3089 bytes .../site-packages/urllib3/util/connection.py | 150 + .../Lib/site-packages/urllib3/util/proxy.py | 57 + .../Lib/site-packages/urllib3/util/queue.py | 22 + .../Lib/site-packages/urllib3/util/request.py | 143 + .../site-packages/urllib3/util/response.py | 107 + .../Lib/site-packages/urllib3/util/retry.py | 602 ++ .../Lib/site-packages/urllib3/util/ssl_.py | 495 + .../urllib3/util/ssltransport.py | 221 + .../Lib/site-packages/urllib3/util/timeout.py | 268 + .../Lib/site-packages/urllib3/util/url.py | 432 + .../Lib/site-packages/urllib3/util/wait.py | 153 + .../Lib/site-packages/werkzeug/__init__.py | 6 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 323 bytes .../__pycache__/_internal.cpython-39.pyc | Bin 0 -> 18433 bytes .../__pycache__/_reloader.cpython-39.pyc | Bin 0 -> 11944 bytes .../__pycache__/datastructures.cpython-39.pyc | Bin 0 -> 106376 bytes .../__pycache__/exceptions.cpython-39.pyc | Bin 0 -> 30208 bytes .../__pycache__/filesystem.cpython-39.pyc | Bin 0 -> 2058 bytes .../__pycache__/formparser.cpython-39.pyc | Bin 0 -> 14064 bytes .../werkzeug/__pycache__/http.cpython-39.pyc | Bin 0 -> 38026 bytes .../werkzeug/__pycache__/local.cpython-39.pyc | Bin 0 -> 22535 bytes .../__pycache__/routing.cpython-39.pyc | Bin 0 -> 73324 bytes .../__pycache__/security.cpython-39.pyc | Bin 0 -> 8144 bytes .../__pycache__/serving.cpython-39.pyc | Bin 0 -> 30734 bytes .../werkzeug/__pycache__/test.cpython-39.pyc | Bin 0 -> 39067 bytes .../__pycache__/testapp.cpython-39.pyc | Bin 0 -> 9587 bytes .../werkzeug/__pycache__/urls.cpython-39.pyc | Bin 0 -> 36597 bytes .../__pycache__/user_agent.cpython-39.pyc | Bin 0 -> 1804 bytes .../__pycache__/useragents.cpython-39.pyc | Bin 0 -> 6846 bytes .../werkzeug/__pycache__/utils.cpython-39.pyc | Bin 0 -> 32926 bytes .../werkzeug/__pycache__/wsgi.cpython-39.pyc | Bin 0 -> 30234 bytes .../Lib/site-packages/werkzeug/_internal.py | 626 ++ .../Lib/site-packages/werkzeug/_reloader.py | 430 + .../site-packages/werkzeug/datastructures.py | 3059 ++++++ .../site-packages/werkzeug/datastructures.pyi | 912 ++ .../site-packages/werkzeug/debug/__init__.py | 502 + .../debug/__pycache__/__init__.cpython-39.pyc | Bin 0 -> 12994 bytes .../debug/__pycache__/console.cpython-39.pyc | Bin 0 -> 7910 bytes .../debug/__pycache__/repr.cpython-39.pyc | Bin 0 -> 8839 bytes .../debug/__pycache__/tbtools.cpython-39.pyc | Bin 0 -> 18017 bytes .../site-packages/werkzeug/debug/console.py | 211 + .../Lib/site-packages/werkzeug/debug/repr.py | 284 + .../werkzeug/debug/shared/FONT_LICENSE | 96 + .../werkzeug/debug/shared/ICON_LICENSE.md | 6 + .../werkzeug/debug/shared/console.png | Bin 0 -> 507 bytes .../werkzeug/debug/shared/debugger.js | 359 + .../werkzeug/debug/shared/less.png | Bin 0 -> 191 bytes .../werkzeug/debug/shared/more.png | Bin 0 -> 200 bytes .../werkzeug/debug/shared/source.png | Bin 0 -> 818 bytes .../werkzeug/debug/shared/style.css | 163 + .../werkzeug/debug/shared/ubuntu.ttf | Bin 0 -> 70220 bytes .../site-packages/werkzeug/debug/tbtools.py | 600 ++ .../Lib/site-packages/werkzeug/exceptions.py | 943 ++ .../Lib/site-packages/werkzeug/filesystem.py | 55 + .../Lib/site-packages/werkzeug/formparser.py | 495 + .../Lib/site-packages/werkzeug/http.py | 1388 +++ .../Lib/site-packages/werkzeug/local.py | 677 ++ .../werkzeug/middleware/__init__.py | 22 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 668 bytes .../__pycache__/dispatcher.cpython-39.pyc | Bin 0 -> 2727 bytes .../__pycache__/http_proxy.cpython-39.pyc | Bin 0 -> 6772 bytes .../__pycache__/lint.cpython-39.pyc | Bin 0 -> 12668 bytes .../__pycache__/profiler.cpython-39.pyc | Bin 0 -> 4920 bytes .../__pycache__/proxy_fix.cpython-39.pyc | Bin 0 -> 6149 bytes .../__pycache__/shared_data.cpython-39.pyc | Bin 0 -> 9826 bytes .../werkzeug/middleware/dispatcher.py | 78 + .../werkzeug/middleware/http_proxy.py | 230 + .../site-packages/werkzeug/middleware/lint.py | 420 + .../werkzeug/middleware/profiler.py | 139 + .../werkzeug/middleware/proxy_fix.py | 187 + .../werkzeug/middleware/shared_data.py | 320 + .../Lib/site-packages/werkzeug/py.typed | 0 .../Lib/site-packages/werkzeug/routing.py | 2341 +++++ .../site-packages/werkzeug/sansio/__init__.py | 0 .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 156 bytes .../__pycache__/multipart.cpython-39.pyc | Bin 0 -> 6507 bytes .../sansio/__pycache__/request.cpython-39.pyc | Bin 0 -> 17152 bytes .../__pycache__/response.cpython-39.pyc | Bin 0 -> 22607 bytes .../sansio/__pycache__/utils.cpython-39.pyc | Bin 0 -> 3860 bytes .../werkzeug/sansio/multipart.py | 260 + .../site-packages/werkzeug/sansio/request.py | 548 ++ .../site-packages/werkzeug/sansio/response.py | 704 ++ .../site-packages/werkzeug/sansio/utils.py | 142 + .../Lib/site-packages/werkzeug/security.py | 247 + .../Lib/site-packages/werkzeug/serving.py | 1081 +++ .../Lib/site-packages/werkzeug/test.py | 1326 +++ .../Lib/site-packages/werkzeug/testapp.py | 240 + .../Lib/site-packages/werkzeug/urls.py | 1211 +++ .../Lib/site-packages/werkzeug/user_agent.py | 47 + .../Lib/site-packages/werkzeug/useragents.py | 215 + .../Lib/site-packages/werkzeug/utils.py | 1099 +++ .../werkzeug/wrappers/__init__.py | 16 + .../__pycache__/__init__.cpython-39.pyc | Bin 0 -> 879 bytes .../__pycache__/accept.cpython-39.pyc | Bin 0 -> 785 bytes .../wrappers/__pycache__/auth.cpython-39.pyc | Bin 0 -> 1263 bytes .../__pycache__/base_request.cpython-39.pyc | Bin 0 -> 1738 bytes .../__pycache__/base_response.cpython-39.pyc | Bin 0 -> 1749 bytes .../common_descriptors.cpython-39.pyc | Bin 0 -> 1340 bytes .../wrappers/__pycache__/cors.cpython-39.pyc | Bin 0 -> 1248 bytes .../wrappers/__pycache__/etag.cpython-39.pyc | Bin 0 -> 1248 bytes .../wrappers/__pycache__/json.cpython-39.pyc | Bin 0 -> 777 bytes .../__pycache__/request.cpython-39.pyc | Bin 0 -> 21276 bytes .../__pycache__/response.cpython-39.pyc | Bin 0 -> 29660 bytes .../__pycache__/user_agent.cpython-39.pyc | Bin 0 -> 798 bytes .../site-packages/werkzeug/wrappers/accept.py | 14 + .../site-packages/werkzeug/wrappers/auth.py | 26 + .../werkzeug/wrappers/base_request.py | 36 + .../werkzeug/wrappers/base_response.py | 36 + .../werkzeug/wrappers/common_descriptors.py | 26 + .../site-packages/werkzeug/wrappers/cors.py | 26 + .../site-packages/werkzeug/wrappers/etag.py | 26 + .../site-packages/werkzeug/wrappers/json.py | 13 + .../werkzeug/wrappers/request.py | 660 ++ .../werkzeug/wrappers/response.py | 890 ++ .../werkzeug/wrappers/user_agent.py | 14 + .../Lib/site-packages/werkzeug/wsgi.py | 982 ++ Rahul/task4/pyvenv3.9/Scripts/Activate.ps1 | 399 + Rahul/task4/pyvenv3.9/Scripts/activate | 66 + Rahul/task4/pyvenv3.9/Scripts/activate.bat | 33 + Rahul/task4/pyvenv3.9/Scripts/deactivate.bat | 21 + Rahul/task4/pyvenv3.9/Scripts/flask.exe | Bin 0 -> 106336 bytes Rahul/task4/pyvenv3.9/Scripts/nltk.exe | Bin 0 -> 106333 bytes Rahul/task4/pyvenv3.9/Scripts/normalizer.exe | Bin 0 -> 106372 bytes Rahul/task4/pyvenv3.9/Scripts/pip.exe | Bin 0 -> 106349 bytes Rahul/task4/pyvenv3.9/Scripts/pip3.9.exe | Bin 0 -> 106349 bytes Rahul/task4/pyvenv3.9/Scripts/pip3.exe | Bin 0 -> 106349 bytes Rahul/task4/pyvenv3.9/Scripts/python.exe | Bin 0 -> 543464 bytes Rahul/task4/pyvenv3.9/Scripts/pythonw.exe | Bin 0 -> 542440 bytes Rahul/task4/pyvenv3.9/Scripts/tqdm.exe | Bin 0 -> 106335 bytes Rahul/task4/pyvenv3.9/pyvenv.cfg | 3 + Rahul/task4/query_processing.py | 35 + Rahul/task4/ranking.py | 57 + Rahul/task4/static/images/logo.png | Bin 0 -> 195981 bytes 3181 files changed, 596441 insertions(+) create mode 100644 Rahul/task4/Crawler/crawler.py create mode 100644 Rahul/task4/Crawler/popularlinks.py create mode 100644 Rahul/task4/Templates/base.html create mode 100644 Rahul/task4/Templates/home.html create mode 100644 Rahul/task4/Templates/search_result.html create mode 100644 Rahul/task4/__pycache__/query_processing.cpython-39.pyc create mode 100644 Rahul/task4/__pycache__/ranking.cpython-39.pyc create mode 100644 Rahul/task4/app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/__pycache__/ranking.cpython-38.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/__pycache__/ranking.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/__pycache__/override.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/override.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/AUTHORS create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/COPYING.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/dammit.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/diagnose.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/element.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/formatter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/testing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__pycache__/_html5lib.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__pycache__/_htmlparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__pycache__/_lxml.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_html5lib.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_htmlparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_lxml.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/dammit.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/diagnose.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/element.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/formatter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/testing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/binary.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/code.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/codec_options.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/dbref.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/decimal128.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/errors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/int64.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/json_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/max_key.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/min_key.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/objectid.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/py3compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/raw_bson.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/regex.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/son.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/timestamp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/tz_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/_cbson.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/binary.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/code.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/codec_options.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/dbref.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/decimal128.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/errors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/int64.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/json_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/max_key.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/min_key.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/objectid.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/py3compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/raw_bson.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/regex.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/son.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/timestamp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/bson/tz_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__main__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__main__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/cacert.pem create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/cd.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/constant.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/legacy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/md.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cd.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/normalizer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/constant.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/legacy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/md.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_termui_impl.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_textwrap.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_unicodefun.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_winconsole.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/decorators.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/formatting.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/globals.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/shell_completion.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/termui.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/testing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/types.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/_termui_impl.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/_textwrap.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/_unicodefun.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/_winconsole.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/decorators.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/formatting.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/globals.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/shell_completion.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/termui.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/testing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/types.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/click/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/ansi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/ansitowin32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/initialise.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/win32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/winterm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansitowin32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/initialise.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/win32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/winterm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/distutils-precedence.pth create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__main__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__main__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/blueprints.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/cli.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/config.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/ctx.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/debughelpers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/globals.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/helpers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/logging.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/scaffold.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/sessions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/signals.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/templating.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/testing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/typing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/views.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/wrappers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/blueprints.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/cli.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/config.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/ctx.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/debughelpers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/globals.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/helpers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__pycache__/tag.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/tag.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/logging.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/scaffold.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/sessions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/signals.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/templating.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/testing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/typing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/views.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask/wrappers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate-2021.10.26.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/flask_paginate/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/__pycache__/errors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/__pycache__/grid_file.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/errors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/gridfs/grid_file.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/LICENSE.md create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna-3.3.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/codec.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/idnadata.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/intranges.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/package_data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/__pycache__/uts46data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/codec.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/idnadata.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/intranges.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/package_data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/idna/uts46data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/LICENSE.rst create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous-2.0.1.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/_json.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/encoding.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/exc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/jws.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/serializer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/signer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/timed.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/__pycache__/url_safe.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/_json.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/encoding.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/exc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/jws.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/serializer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/signer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/timed.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/itsdangerous/url_safe.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/_identifier.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/async_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/bccache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/compiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/constants.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/debug.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/defaults.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/environment.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/ext.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/filters.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/idtracking.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/lexer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/loaders.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/meta.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/nativetypes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/nodes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/optimizer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/runtime.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/sandbox.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/tests.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/__pycache__/visitor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/_identifier.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/async_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/bccache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/compiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/constants.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/debug.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/defaults.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/environment.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/ext.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/filters.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/idtracking.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/lexer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/loaders.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/meta.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/nativetypes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/nodes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/optimizer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/runtime.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/sandbox.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/tests.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/jinja2/visitor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib-1.1.0.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_dask.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_deprecated_format_stack.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_deprecated_my_exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_memmapping_reducer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_multiprocessing_helpers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_parallel_backends.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/_store_backends.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/backports.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/compressor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/disk.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/executor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/format_stack.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/func_inspect.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/hashing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/logger.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/memory.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/my_exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/numpy_pickle.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/numpy_pickle_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/numpy_pickle_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/parallel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/pool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/__pycache__/testing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_dask.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_deprecated_format_stack.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_deprecated_my_exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_memmapping_reducer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_multiprocessing_helpers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_parallel_backends.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/_store_backends.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/backports.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/compressor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/disk.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/executor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/__pycache__/cloudpickle.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/__pycache__/cloudpickle_fast.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/cloudpickle.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/cloudpickle_fast.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/cloudpickle/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/_base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/cloudpickle_wrapper.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/initializers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/process_executor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/__pycache__/reusable_executor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/_base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/_posix_reduction.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/_posix_wait.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/_win_reduction.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/_win_wait.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/compat_posix.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/compat_win32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/context.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/fork_exec.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/managers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/popen_loky_posix.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/popen_loky_win32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/process.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/queues.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/reduction.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/resource_tracker.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/semlock.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/spawn.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/synchronize.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/_posix_reduction.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/_posix_wait.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/_win_reduction.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/_win_wait.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/compat_posix.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/compat_win32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/context.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/fork_exec.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/managers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/popen_loky_posix.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/popen_loky_win32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/process.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/queues.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/reduction.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/resource_tracker.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/semlock.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/spawn.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/synchronize.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/backend/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/cloudpickle_wrapper.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/initializers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/process_executor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/externals/loky/reusable_executor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/format_stack.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/func_inspect.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/hashing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/logger.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/memory.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/my_exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/numpy_pickle.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/numpy_pickle_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/numpy_pickle_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/parallel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/pool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/common.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_backports.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_dask.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_deprecated_objects.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_disk.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_format_stack.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_func_inspect.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_func_inspect_special_encoding.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_hashing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_init.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_logger.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_memmapping.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_memory.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_module.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_my_exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_numpy_pickle.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_numpy_pickle_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_numpy_pickle_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_parallel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_store_backends.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/test_testing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/__pycache__/testutils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/common.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/__pycache__/create_numpy_pickle.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/create_numpy_pickle.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_compressed_pickle_py27_np16.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_compressed_pickle_py27_np17.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_compressed_pickle_py33_np18.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_compressed_pickle_py34_np19.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_compressed_pickle_py35_np19.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py27_np17.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py27_np17.pkl.bz2 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py27_np17.pkl.gzip create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py27_np17.pkl.lzma create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py27_np17.pkl.xz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py33_np18.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py33_np18.pkl.bz2 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py33_np18.pkl.gzip create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py33_np18.pkl.lzma create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py33_np18.pkl.xz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py34_np19.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py34_np19.pkl.bz2 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py34_np19.pkl.gzip create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py34_np19.pkl.lzma create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py34_np19.pkl.xz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py35_np19.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py35_np19.pkl.bz2 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py35_np19.pkl.gzip create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py35_np19.pkl.lzma create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.10.0_pickle_py35_np19.pkl.xz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_compressed_pickle_py36_np111.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_pickle_py36_np111.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_pickle_py36_np111.pkl.bz2 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_pickle_py36_np111.pkl.gzip create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_pickle_py36_np111.pkl.lzma create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.11.0_pickle_py36_np111.pkl.xz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.8.4_compressed_pickle_py27_np17.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_compressed_pickle_py27_np16.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_compressed_pickle_py27_np17.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_compressed_pickle_py34_np19.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_compressed_pickle_py35_np19.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np16.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np16.pkl_01.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np16.pkl_02.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np16.pkl_03.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np16.pkl_04.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np17.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np17.pkl_01.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np17.pkl_02.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np17.pkl_03.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py27_np17.pkl_04.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py33_np18.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py33_np18.pkl_01.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py33_np18.pkl_02.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py33_np18.pkl_03.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py33_np18.pkl_04.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py34_np19.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py34_np19.pkl_01.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py34_np19.pkl_02.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py34_np19.pkl_03.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py34_np19.pkl_04.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py35_np19.pkl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py35_np19.pkl_01.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py35_np19.pkl_02.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py35_np19.pkl_03.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.2_pickle_py35_np19.pkl_04.npy create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.4.dev0_compressed_cache_size_pickle_py35_np19.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.4.dev0_compressed_cache_size_pickle_py35_np19.gz_01.npy.z create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.4.dev0_compressed_cache_size_pickle_py35_np19.gz_02.npy.z create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/data/joblib_0.9.4.dev0_compressed_cache_size_pickle_py35_np19.gz_03.npy.z create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_backports.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_dask.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_deprecated_objects.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_disk.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_format_stack.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_func_inspect.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_func_inspect_special_encoding.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_hashing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_init.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_logger.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_memmapping.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_memory.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_module.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_my_exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_numpy_pickle.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_numpy_pickle_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_numpy_pickle_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_parallel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_store_backends.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/test_testing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/test/testutils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/joblib/testing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/LICENSES.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml-4.6.3.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/ElementInclude.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/ElementInclude.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/_elementpath.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/builder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/cssselect.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/doctestcompare.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/pyclasslookup.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/sax.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/__pycache__/usedoctest.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/_elementpath.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/_elementpath.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/builder.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/builder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/cssselect.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/doctestcompare.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/etree.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/etree.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/etree_api.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/ElementSoup.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/ElementSoup.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/_diffcommand.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/_html5builder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/_setmixin.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/builder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/clean.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/defs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/diff.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/formfill.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/html5parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/soupparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/__pycache__/usedoctest.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/_diffcommand.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/_html5builder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/_setmixin.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/builder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/clean.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/clean.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/defs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/diff.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/diff.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/formfill.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/html5parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/soupparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/html/usedoctest.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/__init__.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/c14n.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/config.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/dtdvalid.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/etree_defs.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/etreepublic.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/htmlparser.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libexslt/exslt.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libexslt/exsltconfig.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libexslt/exsltexports.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libexslt/libexslt.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/DOCBparser.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/HTMLparser.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/HTMLtree.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/SAX.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/SAX2.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/c14n.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/catalog.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/chvalid.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/debugXML.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/dict.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/encoding.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/entities.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/globals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/hash.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/list.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/nanoftp.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/nanohttp.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/parser.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/parserInternals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/pattern.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/relaxng.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/schemasInternals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/schematron.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/threads.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/tree.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/uri.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/valid.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xinclude.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xlink.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlIO.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlautomata.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlerror.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlexports.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlmemory.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlmodule.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlreader.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlregexp.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlsave.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlschemas.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlschemastypes.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlstring.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlunicode.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlversion.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xmlwriter.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xpath.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xpathInternals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxml/xpointer.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/attributes.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/documents.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/extensions.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/extra.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/functions.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/imports.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/keys.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/libxslt.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/namespaces.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/numbersInternals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/preproc.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/security.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/templates.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/transform.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/trio.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/triodef.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/variables.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/win32config.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xslt.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xsltInternals.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xsltconfig.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xsltexports.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xsltlocale.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/libxslt/xsltutils.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/lxml-version.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/relaxng.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/schematron.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/tree.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/uri.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xinclude.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xmlerror.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xmlparser.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xmlschema.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xpath.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/includes/xslt.pxd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/rng/iso-schematron.rng create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/RNG2Schtrn.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/XSD2Schtrn.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/iso_abstract_expand.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/iso_dsdl_include.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/iso_schematron_message.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/iso_schematron_skeleton_for_xslt1.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/iso_svrl_for_xslt1.xsl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/isoschematron/resources/xsl/iso-schematron-xslt1/readme.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/lxml.etree.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/lxml.etree_api.h create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/objectify.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/pyclasslookup.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/sax.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/sax.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/lxml/usedoctest.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/__pycache__/_native.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/_native.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/_speedups.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/_speedups.pyi create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/markupsafe/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/AUTHORS.md create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/README.md create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk-3.6.5.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/VERSION create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/book.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/cli.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/collections.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/collocations.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/decorators.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/downloader.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/featstruct.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/grammar.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/help.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/internals.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/jsontags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/lazyimport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/probability.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/text.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/tgrep.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/toolbox.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/tree.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/treeprettyprinter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/treetransforms.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/__pycache__/wsd.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/chartparser_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/chunkparser_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/collocations_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/concordance_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/nemo_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/rdparser_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/srparser_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/wordfreq_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/__pycache__/wordnet_app.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/chartparser_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/chunkparser_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/collocations_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/concordance_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/nemo_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/rdparser_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/srparser_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/wordfreq_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/app/wordnet_app.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/book.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/chart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/combinator.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/lexicon.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/__pycache__/logic.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/chart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/combinator.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/lexicon.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/ccg/logic.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/eliza.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/iesha.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/rude.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/suntsu.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/__pycache__/zen.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/eliza.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/iesha.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/rude.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/suntsu.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chat/zen.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__pycache__/named_entity.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__pycache__/regexp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/named_entity.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/regexp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/chunk/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/decisiontree.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/maxent.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/megam.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/naivebayes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/positivenaivebayes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/rte_classify.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/scikitlearn.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/senna.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/svm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/tadm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/textcat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/__pycache__/weka.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/decisiontree.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/maxent.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/megam.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/naivebayes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/positivenaivebayes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/rte_classify.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/scikitlearn.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/senna.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/svm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/tadm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/textcat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/classify/weka.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cli.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/em.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/gaac.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/kmeans.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/em.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/gaac.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/kmeans.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/cluster/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/collections.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/collocations.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/__pycache__/europarl_raw.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/europarl_raw.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/aligned.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/bnc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/bracket_parse.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/categorized_sents.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/chasen.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/childes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/chunked.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/cmudict.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/comparative_sents.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/conll.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/crubadan.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/dependency.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/framenet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/ieer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/indian.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/ipipan.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/knbc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/lin.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/mte.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/nkjp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/nombank.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/nps_chat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/opinion_lexicon.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/panlex_lite.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/panlex_swadesh.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/pl196x.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/plaintext.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/ppattach.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/propbank.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/pros_cons.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/reviews.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/rte.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/semcor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/senseval.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/sentiwordnet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/sinica_treebank.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/string_category.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/switchboard.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/tagged.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/timit.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/toolbox.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/twitter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/udhr.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/verbnet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/wordlist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/wordnet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/xmldocs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/__pycache__/ycoe.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/aligned.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/bnc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/bracket_parse.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/categorized_sents.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/chasen.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/childes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/chunked.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/cmudict.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/comparative_sents.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/conll.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/crubadan.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/dependency.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/framenet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/ieer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/indian.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/ipipan.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/knbc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/lin.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/mte.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/nkjp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/nombank.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/nps_chat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/opinion_lexicon.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/panlex_lite.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/panlex_swadesh.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/pl196x.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/plaintext.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/ppattach.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/propbank.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/pros_cons.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/reviews.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/rte.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/semcor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/senseval.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/sentiwordnet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/sinica_treebank.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/string_category.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/switchboard.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/tagged.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/timit.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/toolbox.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/twitter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/udhr.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/verbnet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/wordlist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/wordnet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/xmldocs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/reader/ycoe.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/corpus/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/decorators.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/downloader.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/cfg.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/dispersion.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/table.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/tree.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/cfg.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/dispersion.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/table.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/tree.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/draw/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/featstruct.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/grammar.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/help.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/discourse.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/mace.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/nonmonotonic.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/prover9.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/resolution.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/__pycache__/tableau.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/discourse.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/mace.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/nonmonotonic.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/prover9.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/resolution.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/inference/tableau.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/internals.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/jsontags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lazyimport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/counter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/preprocessing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/smoothing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/__pycache__/vocabulary.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/counter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/preprocessing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/smoothing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/lm/vocabulary.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/agreement.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/aline.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/association.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/confusionmatrix.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/distance.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/paice.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/scores.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/segmentation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/__pycache__/spearman.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/agreement.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/aline.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/association.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/confusionmatrix.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/distance.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/paice.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/scores.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/segmentation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/metrics/spearman.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/babelfish.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/chomsky.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/minimalset.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/sort.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/__pycache__/wordfinder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/babelfish.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/chomsky.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/minimalset.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/sort.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/misc/wordfinder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/bllip.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/chart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/corenlp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/dependencygraph.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/earleychart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/evaluate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/featurechart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/generate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/malt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/nonprojectivedependencyparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/pchart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/projectivedependencyparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/recursivedescent.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/shiftreduce.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/stanford.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/transitionparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/__pycache__/viterbi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/bllip.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/chart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/corenlp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/dependencygraph.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/earleychart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/evaluate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/featurechart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/generate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/malt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/nonprojectivedependencyparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/pchart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/projectivedependencyparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/recursivedescent.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/shiftreduce.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/stanford.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/transitionparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/parse/viterbi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/probability.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/boxer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/chat80.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/cooper_storage.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/drt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/drt_glue_demo.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/evaluate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/glue.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/hole.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/lfg.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/linearlogic.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/logic.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/relextract.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/skolemize.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/boxer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/chat80.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/cooper_storage.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/drt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/drt_glue_demo.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/evaluate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/glue.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/hole.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/lfg.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/linearlogic.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/logic.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/relextract.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/skolemize.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sem/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/__pycache__/sentiment_analyzer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/__pycache__/vader.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/sentiment_analyzer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/sentiment/vader.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/arlstem.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/arlstem2.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/cistem.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/isri.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/lancaster.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/porter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/regexp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/rslp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/snowball.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/__pycache__/wordnet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/arlstem.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/arlstem2.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/cistem.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/isri.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/lancaster.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/porter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/regexp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/rslp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/snowball.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/stem/wordnet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/brill.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/brill_trainer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/crf.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/hmm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/hunpos.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/mapping.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/perceptron.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/senna.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/sequential.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/stanford.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/tnt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/brill.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/brill_trainer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/crf.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/hmm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/hunpos.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/mapping.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/perceptron.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/senna.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/sequential.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/stanford.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/tnt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tag/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/demo.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/erroranalysis.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/feature.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/rule.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/__pycache__/template.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/demo.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/erroranalysis.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/feature.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/rule.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tbl/template.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/all.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/childes_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/classify_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/conftest.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/discourse_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/gensim_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/gluesemantics_malt_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/inference_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/nonmonotonic_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/portuguese_en_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/__pycache__/probability_fixt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/all.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/bleu.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/bnc.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/ccg.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/ccg_semantics.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/chat80.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/childes.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/childes_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/chunk.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/classify.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/classify_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/collections.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/collocations.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/concordance.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/conftest.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/corpus.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/crubadan.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/data.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/dependency.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/discourse.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/discourse_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/drt.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/featgram.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/featstruct.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/framenet.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/generate.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/gensim.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/gensim_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/gluesemantics.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/gluesemantics_malt.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/gluesemantics_malt_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/grammar.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/grammartestsuites.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/index.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/inference.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/inference_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/internals.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/japanese.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/lm.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/logic.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/meteor.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/metrics.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/misc.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/nonmonotonic.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/nonmonotonic_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/paice.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/parse.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/portuguese_en.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/portuguese_en_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/probability.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/probability_fixt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/propbank.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/relextract.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/resolution.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/semantics.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/sentiment.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/sentiwordnet.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/simple.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/stem.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/tag.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/tokenize.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/toolbox.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/translate.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/tree.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/treeprettyprinter.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/treetransforms.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_aline.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_brill.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_cfd_mutation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_cfg2chomsky.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_chunk.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_classify.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_collocations.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_concordance.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_corenlp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_corpora.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_corpus_views.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_disagreement.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_distance.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_freqdist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_hmm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_json2csv_corpus.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_json_serialization.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_metrics.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_naivebayes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_nombank.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_pl196x.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_pos_tag.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_ribes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_rte_classify.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_seekable_unicode_stream_reader.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_senna.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_stem.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_tag.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_tgrep.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_tokenize.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_twitter_auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/__pycache__/test_wordnet.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__pycache__/test_counter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__pycache__/test_models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__pycache__/test_preprocessing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/__pycache__/test_vocabulary.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/test_counter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/test_models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/test_preprocessing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/lm/test_vocabulary.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_aline.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_brill.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_cfd_mutation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_cfg2chomsky.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_chunk.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_classify.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_collocations.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_concordance.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_corenlp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_corpora.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_corpus_views.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_disagreement.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_distance.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_freqdist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_hmm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_json2csv_corpus.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_json_serialization.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_metrics.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_naivebayes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_nombank.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_pl196x.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_pos_tag.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_ribes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_rte_classify.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_seekable_unicode_stream_reader.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_senna.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_stem.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_tag.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_tgrep.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_tokenize.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_twitter_auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/test_wordnet.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_bleu.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_gdfa.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm1.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm2.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm3.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm4.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm5.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_ibm_model.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_meteor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_nist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/__pycache__/test_stack_decoder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_bleu.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_gdfa.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm1.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm2.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm3.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm4.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm5.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_ibm_model.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_meteor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_nist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/unit/translate/test_stack_decoder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/util.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/wordnet.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/wordnet_lch.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/test/wsd.doctest create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/text.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tgrep.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/casual.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/destructive.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/legality_principle.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/mwe.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/nist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/punkt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/regexp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/repp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/sexpr.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/simple.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/sonority_sequencing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/stanford.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/stanford_segmenter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/texttiling.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/toktok.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/treebank.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/casual.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/destructive.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/legality_principle.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/mwe.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/nist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/punkt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/regexp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/repp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/sexpr.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/simple.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/sonority_sequencing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/stanford.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/stanford_segmenter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/texttiling.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/toktok.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/treebank.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tokenize/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/toolbox.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/bleu_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/chrf_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/gale_church.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/gdfa.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/gleu_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm1.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm2.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm3.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm4.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm5.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ibm_model.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/meteor_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/metrics.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/nist_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/phrase_based.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/ribes_score.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/__pycache__/stack_decoder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/bleu_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/chrf_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/gale_church.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/gdfa.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/gleu_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm1.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm2.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm3.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm4.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm5.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ibm_model.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/meteor_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/metrics.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/nist_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/phrase_based.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/ribes_score.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/translate/stack_decoder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/tree.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/treeprettyprinter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/treetransforms.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/common.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/twitter_demo.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/twitterclient.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/common.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/twitter_demo.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/twitterclient.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/twitter/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/nltk/wsd.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/__main__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/build_env.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/autocompletion.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/base_command.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/cmdoptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/command_context.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/main.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/main_parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/progress_bars.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/req_command.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/spinners.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/cli/status_codes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/check.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/completion.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/configuration.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/debug.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/download.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/freeze.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/hash.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/help.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/install.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/list.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/search.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/show.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/uninstall.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/commands/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/configuration.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/installed.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/sdist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/distributions/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/collector.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/package_finder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/index/sources.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/_distutils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/_sysconfig.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/locations/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/main.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/metadata/pkg_resources.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/candidate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/direct_url.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/format_control.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/index.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/link.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/scheme.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/search_scope.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/selection_prefs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/target_python.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/models/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/download.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/lazy_wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/session.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/network/xmlrpc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/metadata.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/check.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/freeze.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/legacy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/install/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/operations/prepare.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/pyproject.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/constructors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/req_file.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/req_install.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/req_set.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/req_tracker.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/req/req_uninstall.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/legacy/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/self_outdated_check.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/appdirs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/compatibility_tags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/datetime.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/deprecation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/distutils_args.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/encoding.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/entrypoints.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/filesystem.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/filetypes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/glibc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/hashes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/inject_securetransport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/logging.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/misc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/packaging.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/parallel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/pkg_resources.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/setuptools_build.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/subprocess.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/temp_dir.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/unpacking.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/urls.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/virtualenv.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/utils/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/bazaar.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/git.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/mercurial.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/subversion.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/vcs/versioncontrol.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_internal/wheel_builder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/appdirs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/controller.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/__main__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/cacert.pem create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/certifi/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/big5freq.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/big5prober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/chardistribution.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/charsetprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/cp949prober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/enums.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/escprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/escsm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/euckrprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/euctwprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/jisfreq.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/jpcntx.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/latin1prober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/mbcssm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/metadata/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/sjisprober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/universaldetector.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/utf8prober.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/chardet/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/ansi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/initialise.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/win32.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/colorama/winterm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/database.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/index.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/locators.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/manifest.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/markers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/metadata.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/resources.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/scripts.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/t32.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/t64.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/w32.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/w64.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distlib/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/distro.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/constants.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/html5parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/serializer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/codec.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/idnadata.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/intranges.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/package_data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/idna/uts46data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/_version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/ext.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/msgpack/fallback.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__about__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/_structures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/_typing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/markers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/requirements.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/specifiers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/tags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/packaging/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/build.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/check.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/colorlog.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/dirtools.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/envbuild.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/meta.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pep517/wrappers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/bar.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/counter.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/progress/spinner.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/pyparsing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/__version__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/_internal_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/adapters.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/certs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/cookies.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/help.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/hooks.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/packages.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/sessions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/status_codes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/structures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/requests/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/compat/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/compat/collections_abc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/providers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/reporters.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/resolvelib/structs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/six.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/after.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/before.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/nap.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/retry.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/stop.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/tenacity/wait.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/decoder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/encoder.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/ordered.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/toml/tz.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/_collections.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/_version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/connection.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_appengine_environ.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/fields.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/filepost.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/backports/makefile.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/six.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/connection.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/queue.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/retry.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/url.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/urllib3/util/wait.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/vendor.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/labels.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/mklabels.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/tests.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/webencodings/x_user_defined.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pip/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/__pycache__/appdirs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/__pycache__/pyparsing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/appdirs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__about__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/__about__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/_structures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/_typing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/markers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/requirements.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/tags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/_structures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/_typing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/markers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/requirements.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/specifiers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/tags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/packaging/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/_vendor/pyparsing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/extern/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/extern/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/tests/data/my-test-package-source/__pycache__/setup.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pkg_resources/tests/data/my-test-package-source/setup.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo-3.12.1.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/_ipaddress.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/aggregation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/auth_aws.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/bulk.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/change_stream.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/client_options.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/client_session.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/collation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/collection.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/command_cursor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/common.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/compression_support.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/cursor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/cursor_manager.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/daemon.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/database.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/driver_info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/encryption.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/encryption_options.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/errors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/event_loggers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/hello.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/hello_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/helpers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ismaster.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/max_staleness_selectors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/message.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/mongo_client.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/mongo_replica_set_client.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/monitor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/monitoring.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/monotonic.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/network.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ocsp_cache.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ocsp_support.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/operations.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/periodic_executor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/pool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/pyopenssl_context.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/read_concern.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/read_preferences.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/results.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/saslprep.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/server.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/server_api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/server_description.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/server_selectors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/server_type.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/settings.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/socket_checker.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/son_manipulator.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/srv_resolver.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ssl_context.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ssl_match_hostname.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/ssl_support.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/thread_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/topology.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/topology_description.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/uri_parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/__pycache__/write_concern.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/_cmessage.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/_ipaddress.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/aggregation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/auth_aws.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/bulk.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/change_stream.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/client_options.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/client_session.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/collation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/collection.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/command_cursor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/common.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/compression_support.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/cursor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/cursor_manager.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/daemon.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/database.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/driver_info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/encryption.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/encryption_options.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/errors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/event_loggers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/hello.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/hello_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/helpers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ismaster.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/max_staleness_selectors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/message.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/mongo_client.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/mongo_replica_set_client.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/monitor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/monitoring.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/monotonic.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/network.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ocsp_cache.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ocsp_support.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/operations.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/periodic_executor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/pool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/pyopenssl_context.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/read_concern.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/read_preferences.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/results.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/saslprep.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/server.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/server_api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/server_description.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/server_selectors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/server_type.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/settings.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/socket_checker.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/son_manipulator.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/srv_resolver.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ssl_context.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ssl_match_hostname.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/ssl_support.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/thread_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/topology.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/topology_description.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/uri_parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pymongo/write_concern.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators-0.3-py3.9.egg-info/PKG-INFO create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators-0.3-py3.9.egg-info/SOURCES.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators-0.3-py3.9.egg-info/dependency_links.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators-0.3-py3.9.egg-info/installed-files.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators-0.3-py3.9.egg-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/decorators.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/linear.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/memory.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/nonlinear.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/norms.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/operators_mpi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/operators_pywt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/decorators.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/algorithms.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/criterions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/dli.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/linesearch.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/__pycache__/optimize.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/algorithms.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/criterions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/dli.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/linesearch.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/iterative/optimize.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/linear.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/memory.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/nonlinear.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/norms.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/operators_mpi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/operators_pywt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyoperators/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/pyspellchecker-0.6.2.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking-0.3.2.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking.egg-info/PKG-INFO create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking.egg-info/SOURCES.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking.egg-info/dependency_links.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking.egg-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/ranking.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex-2021.10.23.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/__pycache__/_regex_core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/__pycache__/regex.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/__pycache__/test_regex.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/_regex.cp39-win_amd64.pyd create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/_regex_core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/regex.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/regex/test_regex.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests-2.26.0.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/__version__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/_internal_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/adapters.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/api.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/certs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/cookies.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/help.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/hooks.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/models.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/packages.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/sessions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/status_codes.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/structures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/__version__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/_internal_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/adapters.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/api.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/certs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/cookies.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/help.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/hooks.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/models.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/packages.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/sessions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/status_codes.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/structures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/requests/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/REQUESTED create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/dependency_links.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools-56.0.0.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/_deprecation_warning.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/_imp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/archive_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/build_meta.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/config.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/dep_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/depends.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/dist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/errors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/extension.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/glob.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/installer.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/launch.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/lib2to3_ex.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/monkey.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/msvc.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/namespaces.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/package_index.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/py34compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/sandbox.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/ssl_support.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/unicode_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/wheel.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/__pycache__/windows_support.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_deprecation_warning.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/_msvccompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/archive_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/bcppcompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/ccompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/cmd.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/config.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/core.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/cygwinccompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/debug.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/dep_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/dir_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/dist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/errors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/extension.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/fancy_getopt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/file_util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/filelist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/log.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/msvc9compiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/msvccompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/py35compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/py38compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/spawn.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/sysconfig.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/text_file.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/unixccompiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/__pycache__/versionpredicate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/_msvccompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/archive_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/bcppcompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/ccompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/cmd.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/bdist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/bdist_dumb.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/bdist_msi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/bdist_rpm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/bdist_wininst.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/build.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/build_clib.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/build_ext.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/build_py.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/build_scripts.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/check.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/clean.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/config.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install_data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install_egg_info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install_headers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install_lib.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/install_scripts.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/py37compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/register.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/sdist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/__pycache__/upload.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/bdist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/bdist_dumb.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/bdist_msi.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/bdist_rpm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/bdist_wininst.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/build.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/build_clib.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/build_ext.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/build_py.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/build_scripts.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/check.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/clean.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/config.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install_data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install_egg_info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install_headers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install_lib.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/install_scripts.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/py37compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/register.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/sdist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/command/upload.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/config.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/core.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/cygwinccompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/debug.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/dep_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/dir_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/dist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/errors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/extension.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/fancy_getopt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/file_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/filelist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/log.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/msvc9compiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/msvccompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/py35compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/py38compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/spawn.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/sysconfig.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/text_file.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/unixccompiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_distutils/versionpredicate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_imp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/__pycache__/ordered_set.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/__pycache__/pyparsing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/ordered_set.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__about__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/__about__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/_compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/_structures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/_typing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/markers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/requirements.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/tags.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/_compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/_structures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/_typing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/markers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/requirements.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/specifiers.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/tags.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/packaging/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/_vendor/pyparsing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/archive_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/build_meta.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/cli-32.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/cli-64.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/cli.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/alias.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/bdist_egg.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/bdist_rpm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/build_clib.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/build_ext.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/build_py.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/develop.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/dist_info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/easy_install.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/egg_info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/install.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/install_egg_info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/install_lib.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/install_scripts.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/py36compat.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/register.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/rotate.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/saveopts.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/sdist.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/setopt.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/test.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/upload.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/__pycache__/upload_docs.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/alias.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/bdist_egg.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/bdist_rpm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/build_clib.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/build_ext.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/build_py.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/develop.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/dist_info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/easy_install.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/egg_info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/install.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/install_egg_info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/install_lib.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/install_scripts.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/launcher manifest.xml create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/py36compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/register.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/rotate.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/saveopts.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/sdist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/setopt.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/test.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/upload.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/command/upload_docs.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/config.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/dep_util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/depends.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/dist.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/errors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/extension.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/extern/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/extern/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/glob.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/gui-32.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/gui-64.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/gui.exe create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/installer.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/launch.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/lib2to3_ex.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/monkey.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/msvc.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/namespaces.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/package_index.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/py34compat.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/sandbox.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/script (dev).tmpl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/script.tmpl create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/ssl_support.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/unicode_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/wheel.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/setuptools/windows_support.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/LICENSE.md create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve-2.2.1.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__meta__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/__meta__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/css_match.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/css_parser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/css_types.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/__pycache__/util.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/css_match.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/css_parser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/css_types.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/soupsieve/util.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/__pycache__/info.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/__pycache__/spellchecker.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/info.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/de.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/en.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/es.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/fr.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/pt.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/resources/ru.json.gz create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/spellchecker.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/spellchecker/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/LICENCE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/entry_points.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm-4.62.3.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__main__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/__main__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_dist_ver.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_main.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_monitor.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_tqdm.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_tqdm_gui.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_tqdm_notebook.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_tqdm_pandas.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/_utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/asyncio.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/auto.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/autonotebook.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/cli.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/dask.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/gui.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/keras.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/notebook.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/rich.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/std.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/tk.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/__pycache__/version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_dist_ver.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_main.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_monitor.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_tqdm.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_tqdm_gui.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_tqdm_notebook.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_tqdm_pandas.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/_utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/asyncio.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/auto.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/autonotebook.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/cli.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/completion.sh create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/bells.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/concurrent.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/discord.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/itertools.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/logging.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/telegram.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/__pycache__/utils_worker.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/bells.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/concurrent.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/discord.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/itertools.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/logging.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/telegram.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/contrib/utils_worker.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/dask.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/gui.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/keras.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/notebook.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/rich.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/std.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/tk.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/tqdm.1 create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/tqdm/version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/INSTALLER create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/LICENSE.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/METADATA create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/RECORD create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/WHEEL create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3-1.26.7.dist-info/top_level.txt create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/_collections.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/_version.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/connection.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/connectionpool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/fields.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/filepost.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/poolmanager.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/_collections.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/_version.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/connection.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/connectionpool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/appengine.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/__pycache__/socks.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_appengine_environ.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/bindings.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/_securetransport/low_level.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/appengine.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/ntlmpool.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/pyopenssl.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/securetransport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/contrib/socks.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/fields.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/filepost.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/__pycache__/six.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/backports/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/backports/makefile.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/six.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/ssl_match_hostname/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/packages/ssl_match_hostname/_implementation.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/poolmanager.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/connection.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/proxy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/queue.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/retry.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/ssl_.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/ssltransport.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/timeout.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/url.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/__pycache__/wait.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/connection.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/proxy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/queue.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/retry.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/ssl_.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/ssltransport.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/timeout.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/url.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/urllib3/util/wait.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/_internal.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/_reloader.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/datastructures.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/exceptions.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/filesystem.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/formparser.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/http.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/local.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/routing.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/security.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/serving.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/test.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/testapp.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/urls.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/user_agent.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/useragents.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/__pycache__/wsgi.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/_internal.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/_reloader.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/datastructures.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/datastructures.pyi create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/__pycache__/console.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/__pycache__/repr.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/__pycache__/tbtools.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/console.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/repr.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/FONT_LICENSE create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/ICON_LICENSE.md create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/console.png create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/debugger.js create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/less.png create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/more.png create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/source.png create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/style.css create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/shared/ubuntu.ttf create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/debug/tbtools.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/exceptions.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/filesystem.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/formparser.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/http.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/local.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/dispatcher.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/http_proxy.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/lint.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/profiler.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/proxy_fix.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/shared_data.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/dispatcher.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/http_proxy.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/lint.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/profiler.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/proxy_fix.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/shared_data.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/py.typed create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/routing.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/multipart.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/utils.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/multipart.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/security.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/serving.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/test.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/testapp.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/urls.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/user_agent.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/useragents.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/utils.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__init__.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/__init__.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/accept.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/auth.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/common_descriptors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/cors.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/etag.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/json.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/request.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/response.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/user_agent.cpython-39.pyc create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/accept.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/auth.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/common_descriptors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/cors.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/etag.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/json.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/request.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/response.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/user_agent.py create mode 100644 Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wsgi.py create mode 100644 Rahul/task4/pyvenv3.9/Scripts/Activate.ps1 create mode 100644 Rahul/task4/pyvenv3.9/Scripts/activate create mode 100644 Rahul/task4/pyvenv3.9/Scripts/activate.bat create mode 100644 Rahul/task4/pyvenv3.9/Scripts/deactivate.bat create mode 100644 Rahul/task4/pyvenv3.9/Scripts/flask.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/nltk.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/normalizer.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/pip.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/pip3.9.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/pip3.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/python.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/pythonw.exe create mode 100644 Rahul/task4/pyvenv3.9/Scripts/tqdm.exe create mode 100644 Rahul/task4/pyvenv3.9/pyvenv.cfg create mode 100644 Rahul/task4/query_processing.py create mode 100644 Rahul/task4/ranking.py create mode 100644 Rahul/task4/static/images/logo.png diff --git a/Rahul/task4/Crawler/crawler.py b/Rahul/task4/Crawler/crawler.py new file mode 100644 index 00000000..e39e5992 --- /dev/null +++ b/Rahul/task4/Crawler/crawler.py @@ -0,0 +1,113 @@ +from bs4 import BeautifulSoup +import requests +import pymongo +import urllib +import sys +from popularlinks import Popularity +import lxml + + +class Crawler(): + + connection_url = "mongodb://127.0.0.1:27017/" + + client = pymongo.MongoClient(connection_url) + + db = client.gluglefinal + + disallowed_links = [] + + def start_crawl(self, url, depth): + robots_url = urllib.parse.urljoin(url, '/robots.txt') + + try: + robots = requests.get(robots_url) + except: + print("robots not found!!!") + self.crawl(url, depth) + + soup = BeautifulSoup(robots.text, 'lxml') + + sample_content = soup.find('p').text + content = sample_content.split() + for word in content: + if word[0] == '/': + self.disallowed_links.append(urllib.parse.urljoin(url, word)) + + print("robots found and appended in disallowed_links...") + + self.crawl(url, depth, self.disallowed_links) + + def crawl(self, url, depth, *disallowed_links): + + try: + print(f"Crawling url {url} at depth: {depth}") + response = requests.get(url) + except: + print(f"Failed to perform HTTP GET request on {url}") + return + + soup = BeautifulSoup(response.text, 'lxml') + + try: + title = soup.find('title').text + description = '' + + for tag in soup.findAll(): + if tag.name == 'p': + description += tag.text.strip().replace('\n', '') + + except: + print("Failed to retrieve title and description...") + return + popularity = Popularity(url) + popularity_score = popularity.popularity_score() + query = { + 'url': url, + 'title': title, + 'description': description, + 'score': 0, + 'popularity': popularity_score, + } + + search_results = self.db.search_results + + search_results.insert_one(query) + + search_results.create_index( + [ + ('url', pymongo.TEXT), + ('title', pymongo.TEXT), + ('description', pymongo.TEXT), + ('score', 1), + ('popularity',1) + ], + name='search_results', + default_language="english" + ) + + if depth == 0: + return + + links = soup.findAll('a') + + for link in links: + try: + if link['href'] not in disallowed_links[0]: + if 'http' in link['href']: + self.crawl(link['href'], depth-1, disallowed_links[0]) + else: + link['href'] = urllib.parse.urljoin(url, link['href']) + self.crawl(link['href'], depth-1, disallowed_links[0]) + except KeyError: + print("no links retrieved from the page") + pass + + self.client.close() + + +crawler = Crawler() + +crawler.start_crawl( + sys.argv[1], int(sys.argv[2]) +) \ No newline at end of file diff --git a/Rahul/task4/Crawler/popularlinks.py b/Rahul/task4/Crawler/popularlinks.py new file mode 100644 index 00000000..ec9912f5 --- /dev/null +++ b/Rahul/task4/Crawler/popularlinks.py @@ -0,0 +1,18 @@ +class Popularity(): + popular_domains = ['https://en.wikipedia.org/', 'https://www.python.org/', 'https://www.rottentomatoes.com/', + 'https://pypi.org/', 'https://www.indiatoday.in/', 'https://www.geeksforgeeks.org/', + 'https://stackoverflow.com/'] + + ps = 0 + + def __init__(self, url): + self.url = url + + def popularity_score(self): + for domain in self.popular_domains: + if domain == self.url: + self.ps += 100/len(self.popular_domains) + if domain in self.url: + self.ps += 100/len(self.popular_domains) + + return self.ps \ No newline at end of file diff --git a/Rahul/task4/Templates/base.html b/Rahul/task4/Templates/base.html new file mode 100644 index 00000000..de09042f --- /dev/null +++ b/Rahul/task4/Templates/base.html @@ -0,0 +1,37 @@ + + + + + + + + + + + + + + Glugle + + + + {% block content %}{% endblock %} + + + + + + + \ No newline at end of file diff --git a/Rahul/task4/Templates/home.html b/Rahul/task4/Templates/home.html new file mode 100644 index 00000000..015db9bd --- /dev/null +++ b/Rahul/task4/Templates/home.html @@ -0,0 +1,22 @@ +{% extends 'base.html' %} + +{% block content %} +
+ + +
+ +

Glugle Search

+
+ + +
+
+ + +
+
+
+{% endblock %} \ No newline at end of file diff --git a/Rahul/task4/Templates/search_result.html b/Rahul/task4/Templates/search_result.html new file mode 100644 index 00000000..3d7e2aab --- /dev/null +++ b/Rahul/task4/Templates/search_result.html @@ -0,0 +1,40 @@ +{% extends 'base.html' %} + +{% block content %} + +
+
+
+ + +
+
+ +
+

Search result for '{{search_string}}'

+
+ + {% if search_result %} + {% for link in search_result %} +
+ + + +
+ {{ link.url }} +

{{ link.description[:300] }}...

+
+
+ {% endfor %} + {% else %} + No results found + {% endif %} + +
+ {{pagination.links}} +
+
+ +{% endblock %} \ No newline at end of file diff --git a/Rahul/task4/__pycache__/query_processing.cpython-39.pyc b/Rahul/task4/__pycache__/query_processing.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..08ee46095eca61800713af3ca78b597f1c3bbe97 GIT binary patch literal 1496 zcmZ`(JC7ST5GJ|r)#H?lVc09wm{~Ke@bGS+ zj`ImjgVc4jBLy%4M=8P{7+LD-yf9Y7*)emWk?NIBVCx5>Gx+=T=;W6dPt{_oCc8})gAiVGyL!_3i z19&*K;YG9wmdvlk9ouZ*!PbfQq#LsJ*v#hZo(MK{Mc-4~$JG^G2Jh%ADuA-vv!^{k^V+rQyq5ncXkEWc&5Ghz#N_V&{ z$WM-CRrtEv?!hFw{0KtXs;%e8-+}!%Omg$n*PP$wsnwGs)mEi4$Dr)a{Rbx|!sEOT zipM!z0?IX%%w``YfC>%Nu|9x(U?gZjQGbD_@tQ|4^*!8j=&Q*^s=b!l1yE@&tIJDi zb=epfZ!6FB=8LAXi_*^8#$|p@l~%g&qMbD^GIKSva2QS@sV>@5f|a9@VU6%z1XoU_ z3zTelUbR}w3hx^yI)!DPwMrDehIzh=&}!cM(yf5Ucdg+N5gOFdnSa-qX{1FTqVOrm zKC?RnpKnw`W7cOQI%J1zNOO9~Vn0Xp9=mz?zu7q*N7zJ7S<9kuc~R7@SSZx{1)wd} zc12@<=^s>kZ+Oqhk=L7-S=*Y2ZEM0S_BxFL^53>qfPu;61b_K+b$&JePdnJ-e@! zMo#(2`!KbWx&L%|mU-W^Qf)t5o^y=_=$Mv1-X1Cs(o>ZlZC`YZy>CWae6)Y}1FY;H DEn;a| literal 0 HcmV?d00001 diff --git a/Rahul/task4/__pycache__/ranking.cpython-39.pyc b/Rahul/task4/__pycache__/ranking.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f40a3b2dccf59395e004aab1edcf834a1c5123d6 GIT binary patch literal 1682 zcmZuxO^@3)5GAQkYd_)ui!JujEYc!~i#C@6Nf87=fG&_r;X~U)A*2vgli6rjmTgMj z)UJHmy%xx|H~UhcxBea;+tXh91AJ-UQ1ZqblmbUH=I( zW4k#pUZ9r`AS9DKXG0!yPP)iNEM79{NcW0K_fo`;6yLF)cMV_G<0i@~H9S>SrF4Hl zW7|!@c!6Gi4xw1gC5wgRQd}{_u`y#;deVpO$v}qq`?7=hkqN#{i}S2F9nkSMjdTk7 zHG0{FsCms2Rtrc3$3ouk2@_~lPV=fX-ejuutmhcFRQYS|Vukh~{$LtNu=T;o(^oI^ z>1nQB>1Mk}A9+q%hLE+ zQ7T=Tjy3bNQpPLCc~%*3th1uBY%pFvdaJbY)A3jp()bN?5RP(b9GG$VI?F+CB@O@C z@R{NBI2g{V^e3FbIajmTfrCDRza>>8LR#*ZD%FEG9q8p_2*zD}k(Dm*@| z;s@vv-?bwV{|s6vd=c{b{)Tu>xLdR%cHYn~hf%X7YrsVMe^>zMGY;*Wg@XhL5W$fg zNr46;JclJbc7y_d!W{MtbZC7*vexJD#>Z=XCWn(AOiXnWlL&qltt~KIqi?0SS5ow*+xk6Ihh7k}MF@4ey0J qcC_c3a5Pprtw!437FVxONvC#pD~=6o3m|;foaQ;zuYF00)c*lc5_$pv literal 0 HcmV?d00001 diff --git a/Rahul/task4/app.py b/Rahul/task4/app.py new file mode 100644 index 00000000..ffa2559e --- /dev/null +++ b/Rahul/task4/app.py @@ -0,0 +1,75 @@ +from flask import Flask, render_template, request +from flask_paginate import Pagination, get_page_args +import pymongo +from ranking import Ranking +import os +from query_processing import QueryProcessing +import time + + +app = Flask(__name__) + + +@app.route('/') +def entry_point(): + return render_template('home.html') + + +@app.route('/search_results') +def search_results(): + connect_url = 'mongodb://127.0.0.1:27017/' + + client = pymongo.MongoClient(connect_url, connect=False) + + db = client.glugle + + search_string = request.args.get('search') + + processor = QueryProcessing(search_string) + keywords = processor.processor() + + query = [] + + start = time.time() + + for keyword in keywords: + query.extend(db.search_results.find( + {'$text': {'$search': search_string, '$caseSensitive': False}})) + + search_result = [] + + for doc in query: + exist = False + for result in search_result: + if result['title'] == doc['title'] or result['url'] == doc['url']: + exist = True + break + + if exist == False: + search_result.append(doc) + + rank = Ranking(search_result,search_string) + + ranked_result = rank.sorted_results() + + client.close() + + page, per_page, offset = get_page_args(page_parameter='page', + per_page_parameter='per_page') + + total = len(search_result) + + pagination = Pagination(page=page, per_page=per_page, total=total, + css_framework='bootstrap4') + + return render_template('search_result.html', + search_result=search_result[offset:offset+per_page], + page=page, + per_page=per_page, + pagination=pagination, + search_string=search_string + ) + + +if __name__ == '__main__': + app.run(debug=True) \ No newline at end of file diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/LICENSE.rst b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/LICENSE.rst new file mode 100644 index 00000000..9d227a0c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/LICENSE.rst @@ -0,0 +1,28 @@ +Copyright 2010 Pallets + +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/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/METADATA new file mode 100644 index 00000000..aaf27cae --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/METADATA @@ -0,0 +1,125 @@ +Metadata-Version: 2.1 +Name: Flask +Version: 2.0.2 +Summary: A simple framework for building complex web applications. +Home-page: https://palletsprojects.com/p/flask +Author: Armin Ronacher +Author-email: armin.ronacher@active-4.com +Maintainer: Pallets +Maintainer-email: contact@palletsprojects.com +License: BSD-3-Clause +Project-URL: Donate, https://palletsprojects.com/donate +Project-URL: Documentation, https://flask.palletsprojects.com/ +Project-URL: Changes, https://flask.palletsprojects.com/changes/ +Project-URL: Source Code, https://github.com/pallets/flask/ +Project-URL: Issue Tracker, https://github.com/pallets/flask/issues/ +Project-URL: Twitter, https://twitter.com/PalletsTeam +Project-URL: Chat, https://discord.gg/pallets +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Framework :: Flask +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content +Classifier: Topic :: Internet :: WWW/HTTP :: WSGI +Classifier: Topic :: Internet :: WWW/HTTP :: WSGI :: Application +Classifier: Topic :: Software Development :: Libraries :: Application Frameworks +Requires-Python: >=3.6 +Description-Content-Type: text/x-rst +License-File: LICENSE.rst +Requires-Dist: Werkzeug (>=2.0) +Requires-Dist: Jinja2 (>=3.0) +Requires-Dist: itsdangerous (>=2.0) +Requires-Dist: click (>=7.1.2) +Provides-Extra: async +Requires-Dist: asgiref (>=3.2) ; extra == 'async' +Provides-Extra: dotenv +Requires-Dist: python-dotenv ; extra == 'dotenv' + +Flask +===== + +Flask is a lightweight `WSGI`_ web application framework. It is designed +to make getting started quick and easy, with the ability to scale up to +complex applications. It began as a simple wrapper around `Werkzeug`_ +and `Jinja`_ and has become one of the most popular Python web +application frameworks. + +Flask offers suggestions, but doesn't enforce any dependencies or +project layout. It is up to the developer to choose the tools and +libraries they want to use. There are many extensions provided by the +community that make adding new functionality easy. + +.. _WSGI: https://wsgi.readthedocs.io/ +.. _Werkzeug: https://werkzeug.palletsprojects.com/ +.. _Jinja: https://jinja.palletsprojects.com/ + + +Installing +---------- + +Install and update using `pip`_: + +.. code-block:: text + + $ pip install -U Flask + +.. _pip: https://pip.pypa.io/en/stable/getting-started/ + + +A Simple Example +---------------- + +.. code-block:: python + + # save this as app.py + from flask import Flask + + app = Flask(__name__) + + @app.route("/") + def hello(): + return "Hello, World!" + +.. code-block:: text + + $ flask run + * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit) + + +Contributing +------------ + +For guidance on setting up a development environment and how to make a +contribution to Flask, see the `contributing guidelines`_. + +.. _contributing guidelines: https://github.com/pallets/flask/blob/main/CONTRIBUTING.rst + + +Donate +------ + +The Pallets organization develops and supports Flask and the libraries +it uses. In order to grow the community of contributors and users, and +allow the maintainers to devote more time to the projects, `please +donate today`_. + +.. _please donate today: https://palletsprojects.com/donate + + +Links +----- + +- Documentation: https://flask.palletsprojects.com/ +- Changes: https://flask.palletsprojects.com/changes/ +- PyPI Releases: https://pypi.org/project/Flask/ +- Source Code: https://github.com/pallets/flask/ +- Issue Tracker: https://github.com/pallets/flask/issues/ +- Website: https://palletsprojects.com/p/flask/ +- Twitter: https://twitter.com/PalletsTeam +- Chat: https://discord.gg/pallets + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/RECORD new file mode 100644 index 00000000..00efd99f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/RECORD @@ -0,0 +1,52 @@ +../../Scripts/flask.exe,sha256=cctm85Fp_yCwq85lq7ekG8zcdl1-LPNP5sKds0Vod9o,106336 +Flask-2.0.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +Flask-2.0.2.dist-info/LICENSE.rst,sha256=SJqOEQhQntmKN7uYPhHg9-HTHwvY-Zp5yESOf_N9B-o,1475 +Flask-2.0.2.dist-info/METADATA,sha256=aKsvjFA_ZjZN1jLh1Ac3aQk-ZUZDPrrwo_TGYW1kdAQ,3839 +Flask-2.0.2.dist-info/RECORD,, +Flask-2.0.2.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +Flask-2.0.2.dist-info/WHEEL,sha256=ewwEueio1C2XeHTvT17n8dZUJgOvyCWCt0WVNLClP9o,92 +Flask-2.0.2.dist-info/entry_points.txt,sha256=gBLA1aKg0OYR8AhbAfg8lnburHtKcgJLDU52BBctN0k,42 +Flask-2.0.2.dist-info/top_level.txt,sha256=dvi65F6AeGWVU0TBpYiC04yM60-FX1gJFkK31IKQr5c,6 +flask/__init__.py,sha256=9ZCelLoNCpr6eSuLmYlzvbp12B3lrLgoN5U2UWk1vdo,2251 +flask/__main__.py,sha256=bYt9eEaoRQWdejEHFD8REx9jxVEdZptECFsV7F49Ink,30 +flask/__pycache__/__init__.cpython-39.pyc,, +flask/__pycache__/__main__.cpython-39.pyc,, +flask/__pycache__/app.cpython-39.pyc,, +flask/__pycache__/blueprints.cpython-39.pyc,, +flask/__pycache__/cli.cpython-39.pyc,, +flask/__pycache__/config.cpython-39.pyc,, +flask/__pycache__/ctx.cpython-39.pyc,, +flask/__pycache__/debughelpers.cpython-39.pyc,, +flask/__pycache__/globals.cpython-39.pyc,, +flask/__pycache__/helpers.cpython-39.pyc,, +flask/__pycache__/logging.cpython-39.pyc,, +flask/__pycache__/scaffold.cpython-39.pyc,, +flask/__pycache__/sessions.cpython-39.pyc,, +flask/__pycache__/signals.cpython-39.pyc,, +flask/__pycache__/templating.cpython-39.pyc,, +flask/__pycache__/testing.cpython-39.pyc,, +flask/__pycache__/typing.cpython-39.pyc,, +flask/__pycache__/views.cpython-39.pyc,, +flask/__pycache__/wrappers.cpython-39.pyc,, +flask/app.py,sha256=ectBbi9hGmVHAse5TNcFQZIDRkDAxYUAnLgfuKD0Xws,81975 +flask/blueprints.py,sha256=AkAVXZ_MMkjwjklzCAMdBNowTiM0wVQPynnUnXjTL2M,23781 +flask/cli.py,sha256=wn2Un9RO32ZfRmCMem5KJ5h62-5lnmy1H9uxgyV-eBs,32238 +flask/config.py,sha256=70Uyjh1Jzb9MfTCT7NDhuZWAzyIEu-TIyk6-22MP3zQ,11285 +flask/ctx.py,sha256=EM3W0v1ctuFQAGk_HWtQdoJEg_r2f5Le4xcmElxFwwk,17428 +flask/debughelpers.py,sha256=W82-xrRmodjopBngI9roYH-q08EbQwN2HEGfDAi6SA0,6184 +flask/globals.py,sha256=cWd-R2hUH3VqPhnmQNww892tQS6Yjqg_wg8UvW1M7NM,1723 +flask/helpers.py,sha256=00WqA3wYeyjMrnAOPZTUyrnUf7H8ik3CVT0kqGl_qjk,30589 +flask/json/__init__.py,sha256=unAKdZBlxMI5OMiTU0-Z2Hl4CF1CMJmqTUzpStiExNw,11822 +flask/json/__pycache__/__init__.cpython-39.pyc,, +flask/json/__pycache__/tag.cpython-39.pyc,, +flask/json/tag.py,sha256=fys3HBLssWHuMAIJuTcf2K0bCtosePBKXIWASZEEjnU,8857 +flask/logging.py,sha256=1o_hirVGqdj7SBdETnhX7IAjklG89RXlrwz_2CjzQQE,2273 +flask/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +flask/scaffold.py,sha256=fM9mRy7QBh9fhJ0VTogVx900dDa5oxz8FOw6OK5F-TU,32796 +flask/sessions.py,sha256=Kb7zY4qBIOU2cw1xM5mQ_KmgYUBDFbUYWjlkq0EFYis,15189 +flask/signals.py,sha256=H7QwDciK-dtBxinjKpexpglP0E6k0MJILiFWTItfmqU,2136 +flask/templating.py,sha256=l96VD39JQ0nue4Bcj7wZ4-FWWs-ppLxvgBCpwDQ4KAk,5626 +flask/testing.py,sha256=OsHT-2B70abWH3ulY9IbhLchXIeyj3L-cfcDa88wv5E,10281 +flask/typing.py,sha256=hXEVcXoH-QEabmy1F11pYaQ2SonlkMAwfjBAnqj2x18,1982 +flask/views.py,sha256=nhq31TRB5Z-z2mjFGZACaaB2Et5XPCmWhWxJxOvLWww,5948 +flask/wrappers.py,sha256=VndbHPRBSUUOejmd2Y3ydkoCVUtsS2OJIdJEVIkBVD8,5604 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/REQUESTED b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/REQUESTED new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/WHEEL new file mode 100644 index 00000000..5bad85fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/entry_points.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/entry_points.txt new file mode 100644 index 00000000..1eb02520 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/entry_points.txt @@ -0,0 +1,3 @@ +[console_scripts] +flask = flask.cli:main + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/top_level.txt new file mode 100644 index 00000000..7e106024 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Flask-2.0.2.dist-info/top_level.txt @@ -0,0 +1 @@ +flask diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/LICENSE.rst b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/LICENSE.rst new file mode 100644 index 00000000..c37cae49 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/LICENSE.rst @@ -0,0 +1,28 @@ +Copyright 2007 Pallets + +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/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/METADATA new file mode 100644 index 00000000..274e91c0 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/METADATA @@ -0,0 +1,113 @@ +Metadata-Version: 2.1 +Name: Jinja2 +Version: 3.0.2 +Summary: A very fast and expressive template engine. +Home-page: https://palletsprojects.com/p/jinja/ +Author: Armin Ronacher +Author-email: armin.ronacher@active-4.com +Maintainer: Pallets +Maintainer-email: contact@palletsprojects.com +License: BSD-3-Clause +Project-URL: Donate, https://palletsprojects.com/donate +Project-URL: Documentation, https://jinja.palletsprojects.com/ +Project-URL: Changes, https://jinja.palletsprojects.com/changes/ +Project-URL: Source Code, https://github.com/pallets/jinja/ +Project-URL: Issue Tracker, https://github.com/pallets/jinja/issues/ +Project-URL: Twitter, https://twitter.com/PalletsTeam +Project-URL: Chat, https://discord.gg/pallets +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content +Classifier: Topic :: Text Processing :: Markup :: HTML +Requires-Python: >=3.6 +Description-Content-Type: text/x-rst +License-File: LICENSE.rst +Requires-Dist: MarkupSafe (>=2.0) +Provides-Extra: i18n +Requires-Dist: Babel (>=2.7) ; extra == 'i18n' + +Jinja +===== + +Jinja is a fast, expressive, extensible templating engine. Special +placeholders in the template allow writing code similar to Python +syntax. Then the template is passed data to render the final document. + +It includes: + +- Template inheritance and inclusion. +- Define and import macros within templates. +- HTML templates can use autoescaping to prevent XSS from untrusted + user input. +- A sandboxed environment can safely render untrusted templates. +- AsyncIO support for generating templates and calling async + functions. +- I18N support with Babel. +- Templates are compiled to optimized Python code just-in-time and + cached, or can be compiled ahead-of-time. +- Exceptions point to the correct line in templates to make debugging + easier. +- Extensible filters, tests, functions, and even syntax. + +Jinja's philosophy is that while application logic belongs in Python if +possible, it shouldn't make the template designer's job difficult by +restricting functionality too much. + + +Installing +---------- + +Install and update using `pip`_: + +.. code-block:: text + + $ pip install -U Jinja2 + +.. _pip: https://pip.pypa.io/en/stable/getting-started/ + + +In A Nutshell +------------- + +.. code-block:: jinja + + {% extends "base.html" %} + {% block title %}Members{% endblock %} + {% block content %} + + {% endblock %} + + +Donate +------ + +The Pallets organization develops and supports Jinja and other popular +packages. In order to grow the community of contributors and users, and +allow the maintainers to devote more time to the projects, `please +donate today`_. + +.. _please donate today: https://palletsprojects.com/donate + + +Links +----- + +- Documentation: https://jinja.palletsprojects.com/ +- Changes: https://jinja.palletsprojects.com/changes/ +- PyPI Releases: https://pypi.org/project/Jinja2/ +- Source Code: https://github.com/pallets/jinja/ +- Issue Tracker: https://github.com/pallets/jinja/issues/ +- Website: https://palletsprojects.com/p/jinja/ +- Twitter: https://twitter.com/PalletsTeam +- Chat: https://discord.gg/pallets + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/RECORD new file mode 100644 index 00000000..ea72b5de --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/RECORD @@ -0,0 +1,58 @@ +Jinja2-3.0.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +Jinja2-3.0.2.dist-info/LICENSE.rst,sha256=O0nc7kEF6ze6wQ-vG-JgQI_oXSUrjp3y4JefweCUQ3s,1475 +Jinja2-3.0.2.dist-info/METADATA,sha256=NxKriGP-LwQjFBZ4hjV696NkZMe3GPy3tE00McDQZZ0,3539 +Jinja2-3.0.2.dist-info/RECORD,, +Jinja2-3.0.2.dist-info/WHEEL,sha256=ewwEueio1C2XeHTvT17n8dZUJgOvyCWCt0WVNLClP9o,92 +Jinja2-3.0.2.dist-info/entry_points.txt,sha256=Qy_DkVo6Xj_zzOtmErrATe8lHZhOqdjpt3e4JJAGyi8,61 +Jinja2-3.0.2.dist-info/top_level.txt,sha256=PkeVWtLb3-CqjWi1fO29OCbj55EhX_chhKrCdrVe_zs,7 +jinja2/__init__.py,sha256=w4sanG5_dogKC4J_2thsPN9tXzmily3fmXK8Pd46Q1Y,2205 +jinja2/__pycache__/__init__.cpython-39.pyc,, +jinja2/__pycache__/_identifier.cpython-39.pyc,, +jinja2/__pycache__/async_utils.cpython-39.pyc,, +jinja2/__pycache__/bccache.cpython-39.pyc,, +jinja2/__pycache__/compiler.cpython-39.pyc,, +jinja2/__pycache__/constants.cpython-39.pyc,, +jinja2/__pycache__/debug.cpython-39.pyc,, +jinja2/__pycache__/defaults.cpython-39.pyc,, +jinja2/__pycache__/environment.cpython-39.pyc,, +jinja2/__pycache__/exceptions.cpython-39.pyc,, +jinja2/__pycache__/ext.cpython-39.pyc,, +jinja2/__pycache__/filters.cpython-39.pyc,, +jinja2/__pycache__/idtracking.cpython-39.pyc,, +jinja2/__pycache__/lexer.cpython-39.pyc,, +jinja2/__pycache__/loaders.cpython-39.pyc,, +jinja2/__pycache__/meta.cpython-39.pyc,, +jinja2/__pycache__/nativetypes.cpython-39.pyc,, +jinja2/__pycache__/nodes.cpython-39.pyc,, +jinja2/__pycache__/optimizer.cpython-39.pyc,, +jinja2/__pycache__/parser.cpython-39.pyc,, +jinja2/__pycache__/runtime.cpython-39.pyc,, +jinja2/__pycache__/sandbox.cpython-39.pyc,, +jinja2/__pycache__/tests.cpython-39.pyc,, +jinja2/__pycache__/utils.cpython-39.pyc,, +jinja2/__pycache__/visitor.cpython-39.pyc,, +jinja2/_identifier.py,sha256=EdgGJKi7O1yvr4yFlvqPNEqV6M1qHyQr8Gt8GmVTKVM,1775 +jinja2/async_utils.py,sha256=bY2nCUfBA_4FSnNUsIsJgljBq3hACr6fzLi7LiyMTn8,1751 +jinja2/bccache.py,sha256=v5rKAlYxIvfJEa0uGzAC6yCYSS3KuXT5Eqi-n9qvNi8,12670 +jinja2/compiler.py,sha256=v7zKz-mgSYXmfXD9mRmi2BU0B6Z-1RGZmOXCrsPKzc0,72209 +jinja2/constants.py,sha256=GMoFydBF_kdpaRKPoM5cl5MviquVRLVyZtfp5-16jg0,1433 +jinja2/debug.py,sha256=uBmrsiwjYH5l14R9STn5mydOOyriBYol5lDGvEqAb3A,9238 +jinja2/defaults.py,sha256=boBcSw78h-lp20YbaXSJsqkAI2uN_mD_TtCydpeq5wU,1267 +jinja2/environment.py,sha256=T6U4be9mY1CUXXin_EQFwpvpFqCiryweGqzXGRYIoSA,61573 +jinja2/exceptions.py,sha256=ioHeHrWwCWNaXX1inHmHVblvc4haO7AXsjCp3GfWvx0,5071 +jinja2/ext.py,sha256=44SjDjeYkkxQTpmC2BetOTxEFMgQ42p2dfSwXmPFcSo,32122 +jinja2/filters.py,sha256=jusKTZbd0ddZMaibZkxMUVKNsOsaYtOq_Il8Imtx4BE,52609 +jinja2/idtracking.py,sha256=WekexMql3u5n3vDxFsQ_i8HW0j24AtjWTjrPBLWrHww,10721 +jinja2/lexer.py,sha256=qNEQqDQw_zO5EaH6rFQsER7Qwn2du0o22prB-TR11HE,29930 +jinja2/loaders.py,sha256=WGJNP5RQEGtuTABIK2tp1sWEy2kfe5ZFOY0ON0gi0LY,22477 +jinja2/meta.py,sha256=GNPEvifmSaU3CMxlbheBOZjeZ277HThOPUTf1RkppKQ,4396 +jinja2/nativetypes.py,sha256=62hvvsAxAj0YaxylOHoREYVogJ5JqOlJISgGY3OKd_o,3675 +jinja2/nodes.py,sha256=8zvzM5mYaylI-kbT6oI1DChxGH8dZkghWt1fVizy4Us,34605 +jinja2/optimizer.py,sha256=tHkMwXxfZkbfA1KmLcqmBMSaz7RLIvvItrJcPoXTyD8,1650 +jinja2/parser.py,sha256=kHnU8v92GwMYkfr0MVakWv8UlSf_kJPx8LUsgQMof70,39767 +jinja2/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +jinja2/runtime.py,sha256=wVRlkEmAgNU67AIQDqLvI6UkNLkzDqpLA-z4Mi3vl3g,35054 +jinja2/sandbox.py,sha256=-8zxR6TO9kUkciAVFsIKu8Oq-C7PTeYEdZ5TtA55-gw,14600 +jinja2/tests.py,sha256=Am5Z6Lmfr2XaH_npIfJJ8MdXtWsbLjMULZJulTAj30E,5905 +jinja2/utils.py,sha256=udQxWIKaq4QDCZiXN31ngKOaGGdaMA5fl0JMaM-F6fg,26971 +jinja2/visitor.py,sha256=ZmeLuTj66ic35-uFH-1m0EKXiw4ObDDb_WuE6h5vPFg,3572 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/WHEEL new file mode 100644 index 00000000..5bad85fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/entry_points.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/entry_points.txt new file mode 100644 index 00000000..3619483f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/entry_points.txt @@ -0,0 +1,3 @@ +[babel.extractors] +jinja2 = jinja2.ext:babel_extract [i18n] + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/top_level.txt new file mode 100644 index 00000000..7f7afbf3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Jinja2-3.0.2.dist-info/top_level.txt @@ -0,0 +1 @@ +jinja2 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/LICENSE.rst b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/LICENSE.rst new file mode 100644 index 00000000..9d227a0c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/LICENSE.rst @@ -0,0 +1,28 @@ +Copyright 2010 Pallets + +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/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/METADATA new file mode 100644 index 00000000..ef44e2b3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/METADATA @@ -0,0 +1,100 @@ +Metadata-Version: 2.1 +Name: MarkupSafe +Version: 2.0.1 +Summary: Safely add untrusted strings to HTML/XML markup. +Home-page: https://palletsprojects.com/p/markupsafe/ +Author: Armin Ronacher +Author-email: armin.ronacher@active-4.com +Maintainer: Pallets +Maintainer-email: contact@palletsprojects.com +License: BSD-3-Clause +Project-URL: Donate, https://palletsprojects.com/donate +Project-URL: Documentation, https://markupsafe.palletsprojects.com/ +Project-URL: Changes, https://markupsafe.palletsprojects.com/changes/ +Project-URL: Source Code, https://github.com/pallets/markupsafe/ +Project-URL: Issue Tracker, https://github.com/pallets/markupsafe/issues/ +Project-URL: Twitter, https://twitter.com/PalletsTeam +Project-URL: Chat, https://discord.gg/pallets +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content +Classifier: Topic :: Text Processing :: Markup :: HTML +Requires-Python: >=3.6 +Description-Content-Type: text/x-rst + +MarkupSafe +========== + +MarkupSafe implements a text object that escapes characters so it is +safe to use in HTML and XML. Characters that have special meanings are +replaced so that they display as the actual characters. This mitigates +injection attacks, meaning untrusted user input can safely be displayed +on a page. + + +Installing +---------- + +Install and update using `pip`_: + +.. code-block:: text + + pip install -U MarkupSafe + +.. _pip: https://pip.pypa.io/en/stable/quickstart/ + + +Examples +-------- + +.. code-block:: pycon + + >>> from markupsafe import Markup, escape + + >>> # escape replaces special characters and wraps in Markup + >>> escape("") + Markup('<script>alert(document.cookie);</script>') + + >>> # wrap in Markup to mark text "safe" and prevent escaping + >>> Markup("Hello") + Markup('hello') + + >>> escape(Markup("Hello")) + Markup('hello') + + >>> # Markup is a str subclass + >>> # methods and operators escape their arguments + >>> template = Markup("Hello {name}") + >>> template.format(name='"World"') + Markup('Hello "World"') + + +Donate +------ + +The Pallets organization develops and supports MarkupSafe and other +popular packages. In order to grow the community of contributors and +users, and allow the maintainers to devote more time to the projects, +`please donate today`_. + +.. _please donate today: https://palletsprojects.com/donate + + +Links +----- + +- Documentation: https://markupsafe.palletsprojects.com/ +- Changes: https://markupsafe.palletsprojects.com/changes/ +- PyPI Releases: https://pypi.org/project/MarkupSafe/ +- Source Code: https://github.com/pallets/markupsafe/ +- Issue Tracker: https://github.com/pallets/markupsafe/issues/ +- Website: https://palletsprojects.com/p/markupsafe/ +- Twitter: https://twitter.com/PalletsTeam +- Chat: https://discord.gg/pallets + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/RECORD new file mode 100644 index 00000000..c5acda27 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/RECORD @@ -0,0 +1,13 @@ +MarkupSafe-2.0.1.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +MarkupSafe-2.0.1.dist-info/LICENSE.rst,sha256=RjHsDbX9kKVH4zaBcmTGeYIUM4FG-KyUtKV_lu6MnsQ,1503 +MarkupSafe-2.0.1.dist-info/METADATA,sha256=FmPpxBdaqCCjF-XKqoxeEzqAzhetQnrkkSsd3V3X-Jc,3211 +MarkupSafe-2.0.1.dist-info/RECORD,, +MarkupSafe-2.0.1.dist-info/WHEEL,sha256=jr7ubY0Lkz_yXH9FfFe9PTtLhGOsf62dZkNvTYrJINE,100 +MarkupSafe-2.0.1.dist-info/top_level.txt,sha256=qy0Plje5IJuvsCBjejJyhDCjEAdcDLK_2agVcex8Z6U,11 +markupsafe/__init__.py,sha256=s08KbuFRV3zh4Wh7xjsIphXgp1xf0EUB79wlPj-4scc,9211 +markupsafe/__pycache__/__init__.cpython-39.pyc,, +markupsafe/__pycache__/_native.cpython-39.pyc,, +markupsafe/_native.py,sha256=JMXegJtk1ZcnRKrgyCA-CEXmRnOpaIXLyDAM98GbshY,2061 +markupsafe/_speedups.cp39-win_amd64.pyd,sha256=hPTsANj9bt7hLYxWLuZcC7E3-EnJQ4GlvIf9Vx0p1p0,16384 +markupsafe/_speedups.pyi,sha256=f5QtwIOP0eLrxh2v5p6SmaYmlcHIGIfmz0DovaqL0OU,238 +markupsafe/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/WHEEL new file mode 100644 index 00000000..d1267fcc --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.36.2) +Root-Is-Purelib: false +Tag: cp39-cp39-win_amd64 + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/top_level.txt new file mode 100644 index 00000000..75bf7292 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/MarkupSafe-2.0.1.dist-info/top_level.txt @@ -0,0 +1 @@ +markupsafe diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/LICENSE.rst b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/LICENSE.rst new file mode 100644 index 00000000..c37cae49 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/LICENSE.rst @@ -0,0 +1,28 @@ +Copyright 2007 Pallets + +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/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/METADATA new file mode 100644 index 00000000..b58b9bd5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/METADATA @@ -0,0 +1,129 @@ +Metadata-Version: 2.1 +Name: Werkzeug +Version: 2.0.2 +Summary: The comprehensive WSGI web application library. +Home-page: https://palletsprojects.com/p/werkzeug/ +Author: Armin Ronacher +Author-email: armin.ronacher@active-4.com +Maintainer: Pallets +Maintainer-email: contact@palletsprojects.com +License: BSD-3-Clause +Project-URL: Donate, https://palletsprojects.com/donate +Project-URL: Documentation, https://werkzeug.palletsprojects.com/ +Project-URL: Changes, https://werkzeug.palletsprojects.com/changes/ +Project-URL: Source Code, https://github.com/pallets/werkzeug/ +Project-URL: Issue Tracker, https://github.com/pallets/werkzeug/issues/ +Project-URL: Twitter, https://twitter.com/PalletsTeam +Project-URL: Chat, https://discord.gg/pallets +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Web Environment +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content +Classifier: Topic :: Internet :: WWW/HTTP :: WSGI +Classifier: Topic :: Internet :: WWW/HTTP :: WSGI :: Application +Classifier: Topic :: Internet :: WWW/HTTP :: WSGI :: Middleware +Classifier: Topic :: Software Development :: Libraries :: Application Frameworks +Requires-Python: >=3.6 +Description-Content-Type: text/x-rst +License-File: LICENSE.rst +Requires-Dist: dataclasses ; python_version < "3.7" +Provides-Extra: watchdog +Requires-Dist: watchdog ; extra == 'watchdog' + +Werkzeug +======== + +*werkzeug* German noun: "tool". Etymology: *werk* ("work"), *zeug* ("stuff") + +Werkzeug is a comprehensive `WSGI`_ web application library. It began as +a simple collection of various utilities for WSGI applications and has +become one of the most advanced WSGI utility libraries. + +It includes: + +- An interactive debugger that allows inspecting stack traces and + source code in the browser with an interactive interpreter for any + frame in the stack. +- A full-featured request object with objects to interact with + headers, query args, form data, files, and cookies. +- A response object that can wrap other WSGI applications and handle + streaming data. +- A routing system for matching URLs to endpoints and generating URLs + for endpoints, with an extensible system for capturing variables + from URLs. +- HTTP utilities to handle entity tags, cache control, dates, user + agents, cookies, files, and more. +- A threaded WSGI server for use while developing applications + locally. +- A test client for simulating HTTP requests during testing without + requiring running a server. + +Werkzeug doesn't enforce any dependencies. It is up to the developer to +choose a template engine, database adapter, and even how to handle +requests. It can be used to build all sorts of end user applications +such as blogs, wikis, or bulletin boards. + +`Flask`_ wraps Werkzeug, using it to handle the details of WSGI while +providing more structure and patterns for defining powerful +applications. + +.. _WSGI: https://wsgi.readthedocs.io/en/latest/ +.. _Flask: https://www.palletsprojects.com/p/flask/ + + +Installing +---------- + +Install and update using `pip`_: + +.. code-block:: text + + pip install -U Werkzeug + +.. _pip: https://pip.pypa.io/en/stable/getting-started/ + + +A Simple Example +---------------- + +.. code-block:: python + + from werkzeug.wrappers import Request, Response + + @Request.application + def application(request): + return Response('Hello, World!') + + if __name__ == '__main__': + from werkzeug.serving import run_simple + run_simple('localhost', 4000, application) + + +Donate +------ + +The Pallets organization develops and supports Werkzeug and other +popular packages. In order to grow the community of contributors and +users, and allow the maintainers to devote more time to the projects, +`please donate today`_. + +.. _please donate today: https://palletsprojects.com/donate + + +Links +----- + +- Documentation: https://werkzeug.palletsprojects.com/ +- Changes: https://werkzeug.palletsprojects.com/changes/ +- PyPI Releases: https://pypi.org/project/Werkzeug/ +- Source Code: https://github.com/pallets/werkzeug/ +- Issue Tracker: https://github.com/pallets/werkzeug/issues/ +- Website: https://palletsprojects.com/p/werkzeug/ +- Twitter: https://twitter.com/PalletsTeam +- Chat: https://discord.gg/pallets + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/RECORD new file mode 100644 index 00000000..5b221529 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/RECORD @@ -0,0 +1,111 @@ +Werkzeug-2.0.2.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +Werkzeug-2.0.2.dist-info/LICENSE.rst,sha256=O0nc7kEF6ze6wQ-vG-JgQI_oXSUrjp3y4JefweCUQ3s,1475 +Werkzeug-2.0.2.dist-info/METADATA,sha256=vh_xrARtpmkFYnWRAgfSiHgl66LH143rMfAfPZo-R_E,4452 +Werkzeug-2.0.2.dist-info/RECORD,, +Werkzeug-2.0.2.dist-info/WHEEL,sha256=ewwEueio1C2XeHTvT17n8dZUJgOvyCWCt0WVNLClP9o,92 +Werkzeug-2.0.2.dist-info/top_level.txt,sha256=QRyj2VjwJoQkrwjwFIOlB8Xg3r9un0NtqVHQF-15xaw,9 +werkzeug/__init__.py,sha256=Wx1PLCftJ7UAS0fBXEO4Prdr6kvEQ124Stwg-XwyhW4,188 +werkzeug/__pycache__/__init__.cpython-39.pyc,, +werkzeug/__pycache__/_internal.cpython-39.pyc,, +werkzeug/__pycache__/_reloader.cpython-39.pyc,, +werkzeug/__pycache__/datastructures.cpython-39.pyc,, +werkzeug/__pycache__/exceptions.cpython-39.pyc,, +werkzeug/__pycache__/filesystem.cpython-39.pyc,, +werkzeug/__pycache__/formparser.cpython-39.pyc,, +werkzeug/__pycache__/http.cpython-39.pyc,, +werkzeug/__pycache__/local.cpython-39.pyc,, +werkzeug/__pycache__/routing.cpython-39.pyc,, +werkzeug/__pycache__/security.cpython-39.pyc,, +werkzeug/__pycache__/serving.cpython-39.pyc,, +werkzeug/__pycache__/test.cpython-39.pyc,, +werkzeug/__pycache__/testapp.cpython-39.pyc,, +werkzeug/__pycache__/urls.cpython-39.pyc,, +werkzeug/__pycache__/user_agent.cpython-39.pyc,, +werkzeug/__pycache__/useragents.cpython-39.pyc,, +werkzeug/__pycache__/utils.cpython-39.pyc,, +werkzeug/__pycache__/wsgi.cpython-39.pyc,, +werkzeug/_internal.py,sha256=_QKkvdaG4pDFwK68c0EpPzYJGe9Y7toRAT1cBbC-CxU,18572 +werkzeug/_reloader.py,sha256=B1hEfgsUOz2IginBQM5Zak_eaIF7gr3GS5-0x2OHvAE,13950 +werkzeug/datastructures.py,sha256=m79A8rHQEt5B7qVqyrjARXzHL66Katn8S92urGscTw4,97929 +werkzeug/datastructures.pyi,sha256=CoVwrQ2Vr9JnbprNL9aE3vOz8mOejT9qysQ-BT53C8Y,34089 +werkzeug/debug/__init__.py,sha256=jYA1e1Gw_8EPOytr-BoMdmm0rzP-Z1H0Ih7wIObnKwQ,17968 +werkzeug/debug/__pycache__/__init__.cpython-39.pyc,, +werkzeug/debug/__pycache__/console.cpython-39.pyc,, +werkzeug/debug/__pycache__/repr.cpython-39.pyc,, +werkzeug/debug/__pycache__/tbtools.cpython-39.pyc,, +werkzeug/debug/console.py,sha256=E1nBMEvFkX673ShQjPtVY-byYatfX9MN-dBMjRI8a8E,5897 +werkzeug/debug/repr.py,sha256=QCSHENKsChEZDCIApkVi_UNjhJ77v8BMXK1OfxO189M,9483 +werkzeug/debug/shared/FONT_LICENSE,sha256=LwAVEI1oYnvXiNMT9SnCH_TaLCxCpeHziDrMg0gPkAI,4673 +werkzeug/debug/shared/ICON_LICENSE.md,sha256=DhA6Y1gUl5Jwfg0NFN9Rj4VWITt8tUx0IvdGf0ux9-s,222 +werkzeug/debug/shared/console.png,sha256=bxax6RXXlvOij_KeqvSNX0ojJf83YbnZ7my-3Gx9w2A,507 +werkzeug/debug/shared/debugger.js,sha256=tg42SZs1SVmYWZ-_Fj5ELK5-FLHnGNQrei0K2By8Bw8,10521 +werkzeug/debug/shared/less.png,sha256=-4-kNRaXJSONVLahrQKUxMwXGm9R4OnZ9SxDGpHlIR4,191 +werkzeug/debug/shared/more.png,sha256=GngN7CioHQoV58rH6ojnkYi8c_qED2Aka5FO5UXrReY,200 +werkzeug/debug/shared/source.png,sha256=RoGcBTE4CyCB85GBuDGTFlAnUqxwTBiIfDqW15EpnUQ,818 +werkzeug/debug/shared/style.css,sha256=h1ZSUVaKNpfbfcYzRb513WAhPySGDQom1uih3uEDxPw,6704 +werkzeug/debug/shared/ubuntu.ttf,sha256=1eaHFyepmy4FyDvjLVzpITrGEBu_CZYY94jE0nED1c0,70220 +werkzeug/debug/tbtools.py,sha256=AFRrjLDCAps7G5K2-RxNZpXXaEoeFHm68T00f4vlDYA,19362 +werkzeug/exceptions.py,sha256=CUwx0pBiNbk4f9cON17ekgKnmLi6HIVFjUmYZc2x0wM,28681 +werkzeug/filesystem.py,sha256=JS2Dv2QF98WILxY4_thHl-WMcUcwluF_4igkDPaP1l4,1956 +werkzeug/formparser.py,sha256=X-p3Ek4ji8XrKrbmaWxr8StLSc6iuksbpIeweaabs4s,17400 +werkzeug/http.py,sha256=oUCXFFMnkOQ-cHbUY_aiqitshcrSzNDq3fEMf1VI_yk,45141 +werkzeug/local.py,sha256=bwL-y3-qOZAspJ66W1P36SUApLXJy3UY8nLYbM9kfmY,23183 +werkzeug/middleware/__init__.py,sha256=qfqgdT5npwG9ses3-FXQJf3aB95JYP1zchetH_T3PUw,500 +werkzeug/middleware/__pycache__/__init__.cpython-39.pyc,, +werkzeug/middleware/__pycache__/dispatcher.cpython-39.pyc,, +werkzeug/middleware/__pycache__/http_proxy.cpython-39.pyc,, +werkzeug/middleware/__pycache__/lint.cpython-39.pyc,, +werkzeug/middleware/__pycache__/profiler.cpython-39.pyc,, +werkzeug/middleware/__pycache__/proxy_fix.cpython-39.pyc,, +werkzeug/middleware/__pycache__/shared_data.cpython-39.pyc,, +werkzeug/middleware/dispatcher.py,sha256=Fh_w-KyWnTSYF-Lfv5dimQ7THSS7afPAZMmvc4zF1gg,2580 +werkzeug/middleware/http_proxy.py,sha256=HE8VyhS7CR-E1O6_9b68huv8FLgGGR1DLYqkS3Xcp3Q,7558 +werkzeug/middleware/lint.py,sha256=sAg3GcOhICIkwYX5bJGG8n8iebX0Yipq_UH0HvrBvoU,13964 +werkzeug/middleware/profiler.py,sha256=QkXk7cqnaPnF8wQu-5SyPCIOT3_kdABUBorQOghVNOA,4899 +werkzeug/middleware/proxy_fix.py,sha256=uRgQ3dEvFV8JxUqajHYYYOPEeA_BFqaa51Yp8VW0uzA,6849 +werkzeug/middleware/shared_data.py,sha256=xydEqOhAGg0aQJEllPDVfz2-8jHwWvJpAxfPsfPCu7k,10960 +werkzeug/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +werkzeug/routing.py,sha256=oqJ32sWIZtIF6zbqfrnwB1Pbv2ShNwPDJd6FYqxdYVo,84527 +werkzeug/sansio/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +werkzeug/sansio/__pycache__/__init__.cpython-39.pyc,, +werkzeug/sansio/__pycache__/multipart.cpython-39.pyc,, +werkzeug/sansio/__pycache__/request.cpython-39.pyc,, +werkzeug/sansio/__pycache__/response.cpython-39.pyc,, +werkzeug/sansio/__pycache__/utils.cpython-39.pyc,, +werkzeug/sansio/multipart.py,sha256=bJMCNC2f5xyAaylahNViJ0JqmV4ThLRbDVGVzKwcqrQ,8751 +werkzeug/sansio/request.py,sha256=aA9rABkWiG4MhYMByanst2NXkEclsq8SIxhb0LQf0e0,20228 +werkzeug/sansio/response.py,sha256=zvCq9HSBBZGBd5Gg412BY9RZIwnKsJl5Kzfd3Kl9sSo,26098 +werkzeug/sansio/utils.py,sha256=V5v-UUnX8pm4RehP9Tt_NiUSOJGJGUvKjlW0eOIQldM,4164 +werkzeug/security.py,sha256=gPDRuCjkjWrcqj99tBMq8_nHFZLFQjgoW5Ga5XIw9jo,8158 +werkzeug/serving.py,sha256=AfgLn0yKr9qXknmwO-0KXJ055oloS4h5DIFDHEu8iHA,38088 +werkzeug/test.py,sha256=8gE1l-Y9yAh2i3SI0kgpxIaI4oYZuehIkxxyDFcz6J0,48123 +werkzeug/testapp.py,sha256=f48prWSGJhbSrvYb8e1fnAah4BkrLb0enHSdChgsjBY,9471 +werkzeug/urls.py,sha256=Du2lreBHvgBh5c2_bcx72g3hzV2ZabXYZsp-picUIJs,41023 +werkzeug/user_agent.py,sha256=WclZhpvgLurMF45hsioSbS75H1Zb4iMQGKN3_yZ2oKo,1420 +werkzeug/useragents.py,sha256=G8tmv_6vxJaPrLQH3eODNgIYe0_V6KETROQlJI-WxDE,7264 +werkzeug/utils.py,sha256=D_dnCLUfodQ4k0GRSpnI6qDoVoaX7-Dza57bx7sabG0,37101 +werkzeug/wrappers/__init__.py,sha256=-s75nPbyXHzU_rwmLPDhoMuGbEUk0jZT_n0ZQAOFGf8,654 +werkzeug/wrappers/__pycache__/__init__.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/accept.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/auth.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/base_request.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/base_response.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/common_descriptors.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/cors.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/etag.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/json.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/request.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/response.cpython-39.pyc,, +werkzeug/wrappers/__pycache__/user_agent.cpython-39.pyc,, +werkzeug/wrappers/accept.py,sha256=_oZtAQkahvsrPRkNj2fieg7_St9P0NFC3SgZbJKS6xU,429 +werkzeug/wrappers/auth.py,sha256=rZPCzGxHk9R55PRkmS90kRywUVjjuMWzCGtH68qCq8U,856 +werkzeug/wrappers/base_request.py,sha256=saz9RyNQkvI_XLPYVm29KijNHmD1YzgxDqa0qHTbgss,1174 +werkzeug/wrappers/base_response.py,sha256=q_-TaYywT5G4zA-DWDRDJhJSat2_4O7gOPob6ye4_9A,1186 +werkzeug/wrappers/common_descriptors.py,sha256=v_kWLH3mvCiSRVJ1FNw7nO3w2UJfzY57UKKB5J4zCvE,898 +werkzeug/wrappers/cors.py,sha256=c5UndlZsZvYkbPrp6Gj5iSXxw_VOJDJHskO6-jRmNyQ,846 +werkzeug/wrappers/etag.py,sha256=XHWQQs7Mdd1oWezgBIsl-bYe8ydKkRZVil2Qd01D0Mo,846 +werkzeug/wrappers/json.py,sha256=HM1btPseGeXca0vnwQN_MvZl6h-qNsFY5YBKXKXFwus,410 +werkzeug/wrappers/request.py,sha256=yZGplfC3UqNuykwLJmgywiMhmnoKEGHJOZn_A_ublcQ,24822 +werkzeug/wrappers/response.py,sha256=0n8OcQptiM2e550SALLeg7vC1uWsUbCeE1rPZFfXR78,35177 +werkzeug/wrappers/user_agent.py,sha256=Wl1-A0-1r8o7cHIZQTB55O4Ged6LpCKENaQDlOY5pXA,435 +werkzeug/wsgi.py,sha256=L7s5-Rlt7BRVEZ1m81MaenGfMDP7yL3p1Kxt9Yssqzg,33727 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/WHEEL new file mode 100644 index 00000000..5bad85fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/top_level.txt new file mode 100644 index 00000000..6fe8da84 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/Werkzeug-2.0.2.dist-info/top_level.txt @@ -0,0 +1 @@ +werkzeug diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/__pycache__/ranking.cpython-38.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/__pycache__/ranking.cpython-38.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e4e0817a40bdeba7dbbc2c30da59ec39dc4fdc72 GIT binary patch literal 5142 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 F`7cA)`dk12 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/__pycache__/override.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/_distutils_hack/__pycache__/override.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..65343a7da9c798bb76691e7159c948ed67a8ec46 GIT binary patch literal 207 zcmYe~<>g`kg6dyYi8?^~F^GcK%!jPc1#iYd-4N!2X?8kLxyS{#FBygtk3.0.0 +Description-Content-Type: text/markdown +Requires-Dist: soupsieve (>1.2) +Provides-Extra: html5lib +Requires-Dist: html5lib ; extra == 'html5lib' +Provides-Extra: lxml +Requires-Dist: lxml ; extra == 'lxml' + +Beautiful Soup is a library that makes it easy to scrape information +from web pages. It sits atop an HTML or XML parser, providing Pythonic +idioms for iterating, searching, and modifying the parse tree. + +# Quick start + +``` +>>> from bs4 import BeautifulSoup +>>> soup = BeautifulSoup("

SomebadHTML") +>>> print(soup.prettify()) + + +

+ Some + + bad + + HTML + + +

+ + +>>> soup.find(text="bad") +'bad' +>>> soup.i +HTML +# +>>> soup = BeautifulSoup("SomebadXML", "xml") +# +>>> print(soup.prettify()) + + + Some + + bad + + XML + + +``` + +To go beyond the basics, [comprehensive documentation is available](http://www.crummy.com/software/BeautifulSoup/bs4/doc/). + +# Links + +* [Homepage](http://www.crummy.com/software/BeautifulSoup/bs4/) +* [Documentation](http://www.crummy.com/software/BeautifulSoup/bs4/doc/) +* [Discussion group](http://groups.google.com/group/beautifulsoup/) +* [Development](https://code.launchpad.net/beautifulsoup/) +* [Bug tracker](https://bugs.launchpad.net/beautifulsoup/) +* [Complete changelog](https://bazaar.launchpad.net/~leonardr/beautifulsoup/bs4/view/head:/CHANGELOG) + +# Note on Python 2 sunsetting + +Beautiful Soup's support for Python 2 was discontinued on December 31, +2020: one year after the sunset date for Python 2 itself. From this +point onward, new Beautiful Soup development will exclusively target +Python 3. The final release of Beautiful Soup 4 to support Python 2 +was 4.9.3. + +# Supporting the project + +If you use Beautiful Soup as part of your professional work, please consider a +[Tidelift subscription](https://tidelift.com/subscription/pkg/pypi-beautifulsoup4?utm_source=pypi-beautifulsoup4&utm_medium=referral&utm_campaign=readme). +This will support many of the free software projects your organization +depends on, not just Beautiful Soup. + +If you use Beautiful Soup for personal projects, the best way to say +thank you is to read +[Tool Safety](https://www.crummy.com/software/BeautifulSoup/zine/), a zine I +wrote about what Beautiful Soup has taught me about software +development. + +# Building the documentation + +The bs4/doc/ directory contains full documentation in Sphinx +format. Run `make html` in that directory to create HTML +documentation. + +# Running the unit tests + +Beautiful Soup supports unit test discovery from the project root directory: + +``` +$ nosetests +``` + +``` +$ python3 -m unittest discover -s bs4 +``` + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/RECORD new file mode 100644 index 00000000..e0d778d5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/RECORD @@ -0,0 +1,29 @@ +beautifulsoup4-4.10.0.dist-info/AUTHORS,sha256=uSIdbrBb1sobdXl7VrlUvuvim2dN9kF3MH4Edn0WKGE,2176 +beautifulsoup4-4.10.0.dist-info/COPYING.txt,sha256=pH6lEjYJhGT-C09Vl0NZC1MwVtngD0nsv4Apn6tH4jE,1315 +beautifulsoup4-4.10.0.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +beautifulsoup4-4.10.0.dist-info/LICENSE,sha256=ynIn3bnu1syAnhV_Z7Ag543eBjJAAB0RhW-FxJy25CM,1447 +beautifulsoup4-4.10.0.dist-info/METADATA,sha256=xXGta_JNOdH5pvsMsrB1-MPPjMDhfi5q22-8r-iTMkg,3542 +beautifulsoup4-4.10.0.dist-info/RECORD,, +beautifulsoup4-4.10.0.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +beautifulsoup4-4.10.0.dist-info/WHEEL,sha256=g4nMs7d-Xl9-xC9XovUrsDHGXt-FT0E17Yqo92DEfvY,92 +beautifulsoup4-4.10.0.dist-info/top_level.txt,sha256=H8VT-IuPWLzQqwG9_eChjXDJ1z0H9RRebdSR90Bjnkw,4 +bs4/__init__.py,sha256=kZ9EDFbdsNtqNkUL95_7epbnZCO7HKgW-s2ukdAXXY0,32673 +bs4/__pycache__/__init__.cpython-39.pyc,, +bs4/__pycache__/dammit.cpython-39.pyc,, +bs4/__pycache__/diagnose.cpython-39.pyc,, +bs4/__pycache__/element.cpython-39.pyc,, +bs4/__pycache__/formatter.cpython-39.pyc,, +bs4/__pycache__/testing.cpython-39.pyc,, +bs4/builder/__init__.py,sha256=FP2SbcvOUZWk8a84wc9-K90F2YA2--nQpxm-GK0G8Gc,19870 +bs4/builder/__pycache__/__init__.cpython-39.pyc,, +bs4/builder/__pycache__/_html5lib.cpython-39.pyc,, +bs4/builder/__pycache__/_htmlparser.cpython-39.pyc,, +bs4/builder/__pycache__/_lxml.cpython-39.pyc,, +bs4/builder/_html5lib.py,sha256=hDxlzVrAku_eU7zEt4gZ-sAXzG58GvkLfMz6P4zUqoA,18748 +bs4/builder/_htmlparser.py,sha256=KjnSpA8C8-_yX4nFd_UwCB4SGO9pzqR05WjjbuZjzH4,18933 +bs4/builder/_lxml.py,sha256=h20vsAgSkeiIPiCKwJ-ggajeaxra7bicCtQSOoinUTc,12699 +bs4/dammit.py,sha256=lMWxYrl9VeLqEgXvk4MJK8isKPgNF_yQXk8B9R4UxXE,98709 +bs4/diagnose.py,sha256=WOzytCTkvqh_fGhqYlMyaYVjtH50w4jbdf1Fd0iundE,7755 +bs4/element.py,sha256=noCV6m4euxWVo3I1Bjh9SYDgG_VNu7oGoWLB0XlCldc,85238 +bs4/formatter.py,sha256=wAuETtbENr2HP-ZiR6WRu4_bLFY8ALRV_BPqWhhr7HA,6385 +bs4/testing.py,sha256=6leLHpE7mHFV7W8SqR3vRvsgEVR3eqxprJVIf8W_bgY,47412 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/REQUESTED b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/REQUESTED new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/WHEEL new file mode 100644 index 00000000..b552003f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.34.2) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/top_level.txt new file mode 100644 index 00000000..13154420 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/beautifulsoup4-4.10.0.dist-info/top_level.txt @@ -0,0 +1 @@ +bs4 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__init__.py new file mode 100644 index 00000000..2a436d34 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__init__.py @@ -0,0 +1,804 @@ +"""Beautiful Soup Elixir and Tonic - "The Screen-Scraper's Friend". + +http://www.crummy.com/software/BeautifulSoup/ + +Beautiful Soup uses a pluggable XML or HTML parser to parse a +(possibly invalid) document into a tree representation. Beautiful Soup +provides methods and Pythonic idioms that make it easy to navigate, +search, and modify the parse tree. + +Beautiful Soup works with Python 3.5 and up. It works better if lxml +and/or html5lib is installed. + +For more than you ever wanted to know about Beautiful Soup, see the +documentation: http://www.crummy.com/software/BeautifulSoup/bs4/doc/ +""" + +__author__ = "Leonard Richardson (leonardr@segfault.org)" +__version__ = "4.10.0" +__copyright__ = "Copyright (c) 2004-2021 Leonard Richardson" +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +__all__ = ['BeautifulSoup'] + + +from collections import Counter +import os +import re +import sys +import traceback +import warnings + +# The very first thing we do is give a useful error if someone is +# running this code under Python 2. +if sys.version_info.major < 3: + raise ImportError('You are trying to use a Python 3-specific version of Beautiful Soup under Python 2. This will not work. The final version of Beautiful Soup to support Python 2 was 4.9.3.') + +from .builder import builder_registry, ParserRejectedMarkup +from .dammit import UnicodeDammit +from .element import ( + CData, + Comment, + DEFAULT_OUTPUT_ENCODING, + Declaration, + Doctype, + NavigableString, + PageElement, + ProcessingInstruction, + PYTHON_SPECIFIC_ENCODINGS, + ResultSet, + Script, + Stylesheet, + SoupStrainer, + Tag, + TemplateString, + ) + +# Define some custom warnings. +class GuessedAtParserWarning(UserWarning): + """The warning issued when BeautifulSoup has to guess what parser to + use -- probably because no parser was specified in the constructor. + """ + +class MarkupResemblesLocatorWarning(UserWarning): + """The warning issued when BeautifulSoup is given 'markup' that + actually looks like a resource locator -- a URL or a path to a file + on disk. + """ + + +class BeautifulSoup(Tag): + """A data structure representing a parsed HTML or XML document. + + Most of the methods you'll call on a BeautifulSoup object are inherited from + PageElement or Tag. + + Internally, this class defines the basic interface called by the + tree builders when converting an HTML/XML document into a data + structure. The interface abstracts away the differences between + parsers. To write a new tree builder, you'll need to understand + these methods as a whole. + + These methods will be called by the BeautifulSoup constructor: + * reset() + * feed(markup) + + The tree builder may call these methods from its feed() implementation: + * handle_starttag(name, attrs) # See note about return value + * handle_endtag(name) + * handle_data(data) # Appends to the current data node + * endData(containerClass) # Ends the current data node + + No matter how complicated the underlying parser is, you should be + able to build a tree using 'start tag' events, 'end tag' events, + 'data' events, and "done with data" events. + + If you encounter an empty-element tag (aka a self-closing tag, + like HTML's
tag), call handle_starttag and then + handle_endtag. + """ + + # Since BeautifulSoup subclasses Tag, it's possible to treat it as + # a Tag with a .name. This name makes it clear the BeautifulSoup + # object isn't a real markup tag. + ROOT_TAG_NAME = '[document]' + + # If the end-user gives no indication which tree builder they + # want, look for one with these features. + DEFAULT_BUILDER_FEATURES = ['html', 'fast'] + + # A string containing all ASCII whitespace characters, used in + # endData() to detect data chunks that seem 'empty'. + ASCII_SPACES = '\x20\x0a\x09\x0c\x0d' + + NO_PARSER_SPECIFIED_WARNING = "No parser was explicitly specified, so I'm using the best available %(markup_type)s parser for this system (\"%(parser)s\"). This usually isn't a problem, but if you run this code on another system, or in a different virtual environment, it may use a different parser and behave differently.\n\nThe code that caused this warning is on line %(line_number)s of the file %(filename)s. To get rid of this warning, pass the additional argument 'features=\"%(parser)s\"' to the BeautifulSoup constructor.\n" + + def __init__(self, markup="", features=None, builder=None, + parse_only=None, from_encoding=None, exclude_encodings=None, + element_classes=None, **kwargs): + """Constructor. + + :param markup: A string or a file-like object representing + markup to be parsed. + + :param features: Desirable features of the parser to be + used. This may be the name of a specific parser ("lxml", + "lxml-xml", "html.parser", or "html5lib") or it may be the + type of markup to be used ("html", "html5", "xml"). It's + recommended that you name a specific parser, so that + Beautiful Soup gives you the same results across platforms + and virtual environments. + + :param builder: A TreeBuilder subclass to instantiate (or + instance to use) instead of looking one up based on + `features`. You only need to use this if you've implemented a + custom TreeBuilder. + + :param parse_only: A SoupStrainer. Only parts of the document + matching the SoupStrainer will be considered. This is useful + when parsing part of a document that would otherwise be too + large to fit into memory. + + :param from_encoding: A string indicating the encoding of the + document to be parsed. Pass this in if Beautiful Soup is + guessing wrongly about the document's encoding. + + :param exclude_encodings: A list of strings indicating + encodings known to be wrong. Pass this in if you don't know + the document's encoding but you know Beautiful Soup's guess is + wrong. + + :param element_classes: A dictionary mapping BeautifulSoup + classes like Tag and NavigableString, to other classes you'd + like to be instantiated instead as the parse tree is + built. This is useful for subclassing Tag or NavigableString + to modify default behavior. + + :param kwargs: For backwards compatibility purposes, the + constructor accepts certain keyword arguments used in + Beautiful Soup 3. None of these arguments do anything in + Beautiful Soup 4; they will result in a warning and then be + ignored. + + Apart from this, any keyword arguments passed into the + BeautifulSoup constructor are propagated to the TreeBuilder + constructor. This makes it possible to configure a + TreeBuilder by passing in arguments, not just by saying which + one to use. + """ + if 'convertEntities' in kwargs: + del kwargs['convertEntities'] + warnings.warn( + "BS4 does not respect the convertEntities argument to the " + "BeautifulSoup constructor. Entities are always converted " + "to Unicode characters.") + + if 'markupMassage' in kwargs: + del kwargs['markupMassage'] + warnings.warn( + "BS4 does not respect the markupMassage argument to the " + "BeautifulSoup constructor. The tree builder is responsible " + "for any necessary markup massage.") + + if 'smartQuotesTo' in kwargs: + del kwargs['smartQuotesTo'] + warnings.warn( + "BS4 does not respect the smartQuotesTo argument to the " + "BeautifulSoup constructor. Smart quotes are always converted " + "to Unicode characters.") + + if 'selfClosingTags' in kwargs: + del kwargs['selfClosingTags'] + warnings.warn( + "BS4 does not respect the selfClosingTags argument to the " + "BeautifulSoup constructor. The tree builder is responsible " + "for understanding self-closing tags.") + + if 'isHTML' in kwargs: + del kwargs['isHTML'] + warnings.warn( + "BS4 does not respect the isHTML argument to the " + "BeautifulSoup constructor. Suggest you use " + "features='lxml' for HTML and features='lxml-xml' for " + "XML.") + + def deprecated_argument(old_name, new_name): + if old_name in kwargs: + warnings.warn( + 'The "%s" argument to the BeautifulSoup constructor ' + 'has been renamed to "%s."' % (old_name, new_name)) + value = kwargs[old_name] + del kwargs[old_name] + return value + return None + + parse_only = parse_only or deprecated_argument( + "parseOnlyThese", "parse_only") + + from_encoding = from_encoding or deprecated_argument( + "fromEncoding", "from_encoding") + + if from_encoding and isinstance(markup, str): + warnings.warn("You provided Unicode markup but also provided a value for from_encoding. Your from_encoding will be ignored.") + from_encoding = None + + self.element_classes = element_classes or dict() + + # We need this information to track whether or not the builder + # was specified well enough that we can omit the 'you need to + # specify a parser' warning. + original_builder = builder + original_features = features + + if isinstance(builder, type): + # A builder class was passed in; it needs to be instantiated. + builder_class = builder + builder = None + elif builder is None: + if isinstance(features, str): + features = [features] + if features is None or len(features) == 0: + features = self.DEFAULT_BUILDER_FEATURES + builder_class = builder_registry.lookup(*features) + if builder_class is None: + raise FeatureNotFound( + "Couldn't find a tree builder with the features you " + "requested: %s. Do you need to install a parser library?" + % ",".join(features)) + + # At this point either we have a TreeBuilder instance in + # builder, or we have a builder_class that we can instantiate + # with the remaining **kwargs. + if builder is None: + builder = builder_class(**kwargs) + if not original_builder and not ( + original_features == builder.NAME or + original_features in builder.ALTERNATE_NAMES + ) and markup: + # The user did not tell us which TreeBuilder to use, + # and we had to guess. Issue a warning. + if builder.is_xml: + markup_type = "XML" + else: + markup_type = "HTML" + + # This code adapted from warnings.py so that we get the same line + # of code as our warnings.warn() call gets, even if the answer is wrong + # (as it may be in a multithreading situation). + caller = None + try: + caller = sys._getframe(1) + except ValueError: + pass + if caller: + globals = caller.f_globals + line_number = caller.f_lineno + else: + globals = sys.__dict__ + line_number= 1 + filename = globals.get('__file__') + if filename: + fnl = filename.lower() + if fnl.endswith((".pyc", ".pyo")): + filename = filename[:-1] + if filename: + # If there is no filename at all, the user is most likely in a REPL, + # and the warning is not necessary. + values = dict( + filename=filename, + line_number=line_number, + parser=builder.NAME, + markup_type=markup_type + ) + warnings.warn( + self.NO_PARSER_SPECIFIED_WARNING % values, + GuessedAtParserWarning, stacklevel=2 + ) + else: + if kwargs: + warnings.warn("Keyword arguments to the BeautifulSoup constructor will be ignored. These would normally be passed into the TreeBuilder constructor, but a TreeBuilder instance was passed in as `builder`.") + + self.builder = builder + self.is_xml = builder.is_xml + self.known_xml = self.is_xml + self._namespaces = dict() + self.parse_only = parse_only + + self.builder.initialize_soup(self) + + if hasattr(markup, 'read'): # It's a file-type object. + markup = markup.read() + elif len(markup) <= 256 and ( + (isinstance(markup, bytes) and not b'<' in markup) + or (isinstance(markup, str) and not '<' in markup) + ): + # Print out warnings for a couple beginner problems + # involving passing non-markup to Beautiful Soup. + # Beautiful Soup will still parse the input as markup, + # just in case that's what the user really wants. + if (isinstance(markup, str) + and not os.path.supports_unicode_filenames): + possible_filename = markup.encode("utf8") + else: + possible_filename = markup + is_file = False + is_directory = False + try: + is_file = os.path.exists(possible_filename) + if is_file: + is_directory = os.path.isdir(possible_filename) + except Exception as e: + # This is almost certainly a problem involving + # characters not valid in filenames on this + # system. Just let it go. + pass + if is_directory: + warnings.warn( + '"%s" looks like a directory name, not markup. You may' + ' want to open a file found in this directory and pass' + ' the filehandle into Beautiful Soup.' % ( + self._decode_markup(markup) + ), + MarkupResemblesLocatorWarning + ) + elif is_file: + warnings.warn( + '"%s" looks like a filename, not markup. You should' + ' probably open this file and pass the filehandle into' + ' Beautiful Soup.' % self._decode_markup(markup), + MarkupResemblesLocatorWarning + ) + self._check_markup_is_url(markup) + + rejections = [] + success = False + for (self.markup, self.original_encoding, self.declared_html_encoding, + self.contains_replacement_characters) in ( + self.builder.prepare_markup( + markup, from_encoding, exclude_encodings=exclude_encodings)): + self.reset() + try: + self._feed() + success = True + break + except ParserRejectedMarkup as e: + rejections.append(e) + pass + + if not success: + other_exceptions = [str(e) for e in rejections] + raise ParserRejectedMarkup( + "The markup you provided was rejected by the parser. Trying a different parser or a different encoding may help.\n\nOriginal exception(s) from parser:\n " + "\n ".join(other_exceptions) + ) + + # Clear out the markup and remove the builder's circular + # reference to this object. + self.markup = None + self.builder.soup = None + + def __copy__(self): + """Copy a BeautifulSoup object by converting the document to a string and parsing it again.""" + copy = type(self)( + self.encode('utf-8'), builder=self.builder, from_encoding='utf-8' + ) + + # Although we encoded the tree to UTF-8, that may not have + # been the encoding of the original markup. Set the copy's + # .original_encoding to reflect the original object's + # .original_encoding. + copy.original_encoding = self.original_encoding + return copy + + def __getstate__(self): + # Frequently a tree builder can't be pickled. + d = dict(self.__dict__) + if 'builder' in d and not self.builder.picklable: + d['builder'] = None + return d + + @classmethod + def _decode_markup(cls, markup): + """Ensure `markup` is bytes so it's safe to send into warnings.warn. + + TODO: warnings.warn had this problem back in 2010 but it might not + anymore. + """ + if isinstance(markup, bytes): + decoded = markup.decode('utf-8', 'replace') + else: + decoded = markup + return decoded + + @classmethod + def _check_markup_is_url(cls, markup): + """Error-handling method to raise a warning if incoming markup looks + like a URL. + + :param markup: A string. + """ + if isinstance(markup, bytes): + space = b' ' + cant_start_with = (b"http:", b"https:") + elif isinstance(markup, str): + space = ' ' + cant_start_with = ("http:", "https:") + else: + return + + if any(markup.startswith(prefix) for prefix in cant_start_with): + if not space in markup: + warnings.warn( + '"%s" looks like a URL. Beautiful Soup is not an' + ' HTTP client. You should probably use an HTTP client like' + ' requests to get the document behind the URL, and feed' + ' that document to Beautiful Soup.' % cls._decode_markup( + markup + ), + MarkupResemblesLocatorWarning + ) + + def _feed(self): + """Internal method that parses previously set markup, creating a large + number of Tag and NavigableString objects. + """ + # Convert the document to Unicode. + self.builder.reset() + + self.builder.feed(self.markup) + # Close out any unfinished strings and close all the open tags. + self.endData() + while self.currentTag.name != self.ROOT_TAG_NAME: + self.popTag() + + def reset(self): + """Reset this object to a state as though it had never parsed any + markup. + """ + Tag.__init__(self, self, self.builder, self.ROOT_TAG_NAME) + self.hidden = 1 + self.builder.reset() + self.current_data = [] + self.currentTag = None + self.tagStack = [] + self.open_tag_counter = Counter() + self.preserve_whitespace_tag_stack = [] + self.string_container_stack = [] + self.pushTag(self) + + def new_tag(self, name, namespace=None, nsprefix=None, attrs={}, + sourceline=None, sourcepos=None, **kwattrs): + """Create a new Tag associated with this BeautifulSoup object. + + :param name: The name of the new Tag. + :param namespace: The URI of the new Tag's XML namespace, if any. + :param prefix: The prefix for the new Tag's XML namespace, if any. + :param attrs: A dictionary of this Tag's attribute values; can + be used instead of `kwattrs` for attributes like 'class' + that are reserved words in Python. + :param sourceline: The line number where this tag was + (purportedly) found in its source document. + :param sourcepos: The character position within `sourceline` where this + tag was (purportedly) found. + :param kwattrs: Keyword arguments for the new Tag's attribute values. + + """ + kwattrs.update(attrs) + return self.element_classes.get(Tag, Tag)( + None, self.builder, name, namespace, nsprefix, kwattrs, + sourceline=sourceline, sourcepos=sourcepos + ) + + def string_container(self, base_class=None): + container = base_class or NavigableString + + # There may be a general override of NavigableString. + container = self.element_classes.get( + container, container + ) + + # On top of that, we may be inside a tag that needs a special + # container class. + if self.string_container_stack and container is NavigableString: + container = self.builder.string_containers.get( + self.string_container_stack[-1].name, container + ) + return container + + def new_string(self, s, subclass=None): + """Create a new NavigableString associated with this BeautifulSoup + object. + """ + container = self.string_container(subclass) + return container(s) + + def insert_before(self, *args): + """This method is part of the PageElement API, but `BeautifulSoup` doesn't implement + it because there is nothing before or after it in the parse tree. + """ + raise NotImplementedError("BeautifulSoup objects don't support insert_before().") + + def insert_after(self, *args): + """This method is part of the PageElement API, but `BeautifulSoup` doesn't implement + it because there is nothing before or after it in the parse tree. + """ + raise NotImplementedError("BeautifulSoup objects don't support insert_after().") + + def popTag(self): + """Internal method called by _popToTag when a tag is closed.""" + tag = self.tagStack.pop() + if tag.name in self.open_tag_counter: + self.open_tag_counter[tag.name] -= 1 + if self.preserve_whitespace_tag_stack and tag == self.preserve_whitespace_tag_stack[-1]: + self.preserve_whitespace_tag_stack.pop() + if self.string_container_stack and tag == self.string_container_stack[-1]: + self.string_container_stack.pop() + #print("Pop", tag.name) + if self.tagStack: + self.currentTag = self.tagStack[-1] + return self.currentTag + + def pushTag(self, tag): + """Internal method called by handle_starttag when a tag is opened.""" + #print("Push", tag.name) + if self.currentTag is not None: + self.currentTag.contents.append(tag) + self.tagStack.append(tag) + self.currentTag = self.tagStack[-1] + if tag.name != self.ROOT_TAG_NAME: + self.open_tag_counter[tag.name] += 1 + if tag.name in self.builder.preserve_whitespace_tags: + self.preserve_whitespace_tag_stack.append(tag) + if tag.name in self.builder.string_containers: + self.string_container_stack.append(tag) + + def endData(self, containerClass=None): + """Method called by the TreeBuilder when the end of a data segment + occurs. + """ + if self.current_data: + current_data = ''.join(self.current_data) + # If whitespace is not preserved, and this string contains + # nothing but ASCII spaces, replace it with a single space + # or newline. + if not self.preserve_whitespace_tag_stack: + strippable = True + for i in current_data: + if i not in self.ASCII_SPACES: + strippable = False + break + if strippable: + if '\n' in current_data: + current_data = '\n' + else: + current_data = ' ' + + # Reset the data collector. + self.current_data = [] + + # Should we add this string to the tree at all? + if self.parse_only and len(self.tagStack) <= 1 and \ + (not self.parse_only.text or \ + not self.parse_only.search(current_data)): + return + + containerClass = self.string_container(containerClass) + o = containerClass(current_data) + self.object_was_parsed(o) + + def object_was_parsed(self, o, parent=None, most_recent_element=None): + """Method called by the TreeBuilder to integrate an object into the parse tree.""" + if parent is None: + parent = self.currentTag + if most_recent_element is not None: + previous_element = most_recent_element + else: + previous_element = self._most_recent_element + + next_element = previous_sibling = next_sibling = None + if isinstance(o, Tag): + next_element = o.next_element + next_sibling = o.next_sibling + previous_sibling = o.previous_sibling + if previous_element is None: + previous_element = o.previous_element + + fix = parent.next_element is not None + + o.setup(parent, previous_element, next_element, previous_sibling, next_sibling) + + self._most_recent_element = o + parent.contents.append(o) + + # Check if we are inserting into an already parsed node. + if fix: + self._linkage_fixer(parent) + + def _linkage_fixer(self, el): + """Make sure linkage of this fragment is sound.""" + + first = el.contents[0] + child = el.contents[-1] + descendant = child + + if child is first and el.parent is not None: + # Parent should be linked to first child + el.next_element = child + # We are no longer linked to whatever this element is + prev_el = child.previous_element + if prev_el is not None and prev_el is not el: + prev_el.next_element = None + # First child should be linked to the parent, and no previous siblings. + child.previous_element = el + child.previous_sibling = None + + # We have no sibling as we've been appended as the last. + child.next_sibling = None + + # This index is a tag, dig deeper for a "last descendant" + if isinstance(child, Tag) and child.contents: + descendant = child._last_descendant(False) + + # As the final step, link last descendant. It should be linked + # to the parent's next sibling (if found), else walk up the chain + # and find a parent with a sibling. It should have no next sibling. + descendant.next_element = None + descendant.next_sibling = None + target = el + while True: + if target is None: + break + elif target.next_sibling is not None: + descendant.next_element = target.next_sibling + target.next_sibling.previous_element = child + break + target = target.parent + + def _popToTag(self, name, nsprefix=None, inclusivePop=True): + """Pops the tag stack up to and including the most recent + instance of the given tag. + + If there are no open tags with the given name, nothing will be + popped. + + :param name: Pop up to the most recent tag with this name. + :param nsprefix: The namespace prefix that goes with `name`. + :param inclusivePop: It this is false, pops the tag stack up + to but *not* including the most recent instqance of the + given tag. + + """ + #print("Popping to %s" % name) + if name == self.ROOT_TAG_NAME: + # The BeautifulSoup object itself can never be popped. + return + + most_recently_popped = None + + stack_size = len(self.tagStack) + for i in range(stack_size - 1, 0, -1): + if not self.open_tag_counter.get(name): + break + t = self.tagStack[i] + if (name == t.name and nsprefix == t.prefix): + if inclusivePop: + most_recently_popped = self.popTag() + break + most_recently_popped = self.popTag() + + return most_recently_popped + + def handle_starttag(self, name, namespace, nsprefix, attrs, sourceline=None, + sourcepos=None): + """Called by the tree builder when a new tag is encountered. + + :param name: Name of the tag. + :param nsprefix: Namespace prefix for the tag. + :param attrs: A dictionary of attribute values. + :param sourceline: The line number where this tag was found in its + source document. + :param sourcepos: The character position within `sourceline` where this + tag was found. + + If this method returns None, the tag was rejected by an active + SoupStrainer. You should proceed as if the tag had not occurred + in the document. For instance, if this was a self-closing tag, + don't call handle_endtag. + """ + # print("Start tag %s: %s" % (name, attrs)) + self.endData() + + if (self.parse_only and len(self.tagStack) <= 1 + and (self.parse_only.text + or not self.parse_only.search_tag(name, attrs))): + return None + + tag = self.element_classes.get(Tag, Tag)( + self, self.builder, name, namespace, nsprefix, attrs, + self.currentTag, self._most_recent_element, + sourceline=sourceline, sourcepos=sourcepos + ) + if tag is None: + return tag + if self._most_recent_element is not None: + self._most_recent_element.next_element = tag + self._most_recent_element = tag + self.pushTag(tag) + return tag + + def handle_endtag(self, name, nsprefix=None): + """Called by the tree builder when an ending tag is encountered. + + :param name: Name of the tag. + :param nsprefix: Namespace prefix for the tag. + """ + #print("End tag: " + name) + self.endData() + self._popToTag(name, nsprefix) + + def handle_data(self, data): + """Called by the tree builder when a chunk of textual data is encountered.""" + self.current_data.append(data) + + def decode(self, pretty_print=False, + eventual_encoding=DEFAULT_OUTPUT_ENCODING, + formatter="minimal"): + """Returns a string or Unicode representation of the parse tree + as an HTML or XML document. + + :param pretty_print: If this is True, indentation will be used to + make the document more readable. + :param eventual_encoding: The encoding of the final document. + If this is None, the document will be a Unicode string. + """ + if self.is_xml: + # Print the XML declaration + encoding_part = '' + if eventual_encoding in PYTHON_SPECIFIC_ENCODINGS: + # This is a special Python encoding; it can't actually + # go into an XML document because it means nothing + # outside of Python. + eventual_encoding = None + if eventual_encoding != None: + encoding_part = ' encoding="%s"' % eventual_encoding + prefix = '\n' % encoding_part + else: + prefix = '' + if not pretty_print: + indent_level = None + else: + indent_level = 0 + return prefix + super(BeautifulSoup, self).decode( + indent_level, eventual_encoding, formatter) + +# Aliases to make it easier to get started quickly, e.g. 'from bs4 import _soup' +_s = BeautifulSoup +_soup = BeautifulSoup + +class BeautifulStoneSoup(BeautifulSoup): + """Deprecated interface to an XML parser.""" + + def __init__(self, *args, **kwargs): + kwargs['features'] = 'xml' + warnings.warn( + 'The BeautifulStoneSoup class is deprecated. Instead of using ' + 'it, pass features="xml" into the BeautifulSoup constructor.') + super(BeautifulStoneSoup, self).__init__(*args, **kwargs) + + +class StopParsing(Exception): + """Exception raised by a TreeBuilder if it's unable to continue parsing.""" + pass + +class FeatureNotFound(ValueError): + """Exception raised by the BeautifulSoup constructor if no parser with the + requested features is found. + """ + pass + + +#If this file is run as a script, act as an HTML pretty-printer. +if __name__ == '__main__': + import sys + soup = BeautifulSoup(sys.stdin) + print((soup.prettify())) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..1cf9361c0c1d38ed3870144a9a51a2bd9d17f7fc GIT binary patch literal 23158 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 PlcSUANrc|hwEzDB5W@)W literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/dammit.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/dammit.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2ea626f7bf3ead13389804affc4d890a238faffa GIT binary patch literal 71344 zcmc${2Ygh=xi_rUo^y6p5Y;VpP2z$JiCc`+9pX+{FuvK_M8SxF14U9m+%3M9e^ zRop-VcfdgcN$%Z_OJbumJ0Q~U<|esudb!C>a($DK`(`ruh6hWIk*@Vm@jvHS^46=40k^bA|c1nQs=Dg=UedG>gp=v(zjz??z|| z?q12b$}Bf4%u2+qGONwij5Vgp5UR~uv(8*&t~J-08gsq5!Q5y*Vb zXZD)|=6>^8bI=T$A#=zaHp6DbjG70`gXSUguzAEhY92F>n0ZM@~pj<)srT`U+si1|JW~vc09hd>k1ZDvz0Ve~e0H*?{ z0q+3b3A_tHr$@KNAWU>-8EPq-Gi4yXaH z2W|jv1U>=K^Hk1y;FCaDX)S03Fr13|mQqqHM1eYhTA?0j0Aj!fU?UI*8i52rEoNIT z3BC!~1W>zhJwa1I8pr@ypc!ZZHUq6d8}KP$3$PXVH1HXq9oPok1Z)R7fE_?5-=&he zfNr1%=mq+Koxsfn^cL{90=EIT1G|9T1+*Xh0I&z3Ufc^%8{Gli3ETzT4cr6V3)~0n zE1>(q9{}zLJ_{TK27w{q5O5e621XR4N*@4y5O@f97Td@B`q7 zz`p@M0$vAxtoRA&Pl2BSKL>uH_$BDC6u$=j4e;;4Z-L(d|DpIj=pTST0{;oT0sI&6 zC*aQj<@*=l1n^hjZ@}MyYT& zS^-Q2rUBD|8Nf_n7H|@9veHvPPX$f`-T}N5co*<);5~}>f`$~tpAO6h-UoSCfs!mF z2g&e$fbt<(&H&B?&Qktt&^f?41t2*nd@gVva6T{>_yD&@F>Ig2QT|k4%A4}NfMC9k z>xD@93($*zi-AiJt^@rL@L}L1z(;{gfqB4Xz{eDqgI)oA9GDMK9t(hlz#^a$SPU!y zmIBLwE1`Lk@+wfubvdwt=3UU0D4j~Cc3E9OuLi#cs4Ae<;MW4{fNOwjf$JDjgBtMH z12+IS7SKFzyMu7)_2Z4uxhk-|cM}fzH$CW+-O81{skbR||c^Y^IcoujL zApQCr@I3GW@FMUM@Oj`1z{|iZz!6{!_#*Hn;LE^QfUg3t0&UmjeH-`=@Lk|v0Fs=nf1!jq#E~?V)Asqo%<82AbBQ{ZR7&w*b6zXW~-{2KTTK>7VU@LS+_0Lex&{)giCpnm}V z2>d7T2Jl}1wf3I?dd5CW&;42P7tj*`a5!(~(y_Q$KsK4d7=0 zGl5yS7h_5q;)mV#!*2WG)%szx{jk}7*h4>TwjVaz51Z|W&Gy5q1uzEvu-bmM)-(sw znEVmKvw`;k?+4C6+(V#e0%tL(b^P#n{cNef40;Z5E^r=jJ}|ccuJRuM{UGw99{4Hv z3xErOi-3y}_X~`8KPRYClx6`uj6e%c1y zq}UGH0qg)efi9pM=uy5Gv=7(`+zi|T+zQ+V*f{$<#nHXn6}v!p1O31NK;b>WUf>Sk zPT($p+K$@rZr~o^UZqsu`+$AGet_Dk1)%zp{8UG(AJyRiK=q{h**>6W?gu^#5PuLD z1W1Mzr`T+1C@DT7YK=&R29t9o)9tWNPo&=r(o(7%) zo&}x*J_kGxya2oiyaaq6AiW^{qV}M=621Vu47>tRnN%K?Ys)_Zehl~`@Fl>8Ngk4g z%B1qB+%E%P0c`%ZTq@hfk=!KnSAkanlH1BpVakv4dJXs*K=RvqP?*~PC~&NRQk&ZT zwsMUl?l|yu;2Xdp#Kj3x90b_{tloN*zv%X@JHZ3fj5Bv0{#U28TbouqJaJt z{NDib@yju@`7z7*G0QlZT^!6V4rUjJXP3W&I)Dp!Kmd6=m{%OkD-Qd<)E4J}FGGnA zW){ax!CdEHPH`}&2&RD&rYmNE&ID!wCqZHdmO)aU0(vT7>1p8K0lc$-z6iwZL^i4RAeh18Th<^hV$l0P&v$!iXn%Yk>&z{5+_66QT&$0rfxw z5Cb*<8-X~`2vGkKpHwsoyEU{-U8gJxJ~Kppu5Z; zb<}nz@5Ndz}*0~z$VsLl1jq;fGw6?i*MT1cKLKd(<`U#ZbJJDe zNvAgfKLdWQ_yy=MfnOx~xftm#?7a(nPaw%$*nJl^--XS0+2+SU13<8VmVhq>EG+|X zLC@Rt_P&cVimfPf6YiA*Q&`$RfvZqV<=s)zfeRu3M-e*>m=4SUW&*Q-lYoF8OCr~4NG7XlZdmluLw44K}| zaG_By<{rU^K|caeyIqQUkX-YC%YcsomjhP-9|z_G3joS*5l~rx#o(6!O9{B^!2fVD zzqpuNfPBnV2rUPMQYs(MB((b&MoyHHgOT1UG$*Q5G$aM?S+bpl;LH$XE0?crLvdl5(S^dXMq z?gMCUv}Mw|iTqBIdna(S(p!k<6%*;pt-x)H+d+2$yMcaS0N4ZU1?~Xu1g_zF&{KB- zcNfrmz~2j5o`(!~fsR1l3xN*-4$mNp8{?K7zG{x9t0lBQ?ii~ei-x-lyD*FqX6wXk!McU`UQj^2WTE6 z9i>vA1fBv&LXwn9BuSqJo&lZ(o&!FI)7f)Cp9d(P7lD_6&jVioDDDx(%b>65DKBZy z5rEDp8X&_A@LvSztfC&_>A*~czs%P3E8xCL=fb#4YcjHcuL7^(oOm-%iE&1Z(AR*Y z1@svBao{-cb>JJoH-T>{z76^v;Jd)T06E}$z`p|D2Yvwj5coIXM@nA@{W0(p;HLnM zpq~T30DcM3%7#YBuYuoi*v0JTVzuC6W^;KLj7HP%fjqAMdt!TW&AT}6uZa5_$Ndd)?>25#(b<1@i;BVv zd__eIqTy^NR+o*3s*>5JP;D}iO^4#K+Eh5zdTD5FA{I%S=y{<<;l{>TrnI!WA(p=# ziX;=w(NrcK3WsW2GtqP=6%99rGD-VbDASNiX6qY5;Y4ewF&a*!OB2yZG@VA?b3@BA zA>`E%4L8T)t)bd*I%-161TrSR!*_BHS27Oqq$+g|qRDiA6FiBWUsbf5iKNg+TgUxMYg96lHwd zi&GV*sH!Mayx+g2=m1XYPeW+9cx5hVWt!vUN@M9*BAp2*BGH^5EuRZUA`Rh`iDq&h zE~v+_FXu}S7p0~k=Mxv1OK+%;XY1q98=6|1qlxB==6>{s<+0iu(rAqHo5GQe;reL$ zhT8PSA28h2bDLUG8Od?IM4d)*dbkw%N_~zmH5J_dd4*EYz@j-$DgctgJ3>XdfEJgc z7m8A4bRpU0Qb8P*_&%UOinjlgiVh%BL&$;1>%iBJ98B#SyGvVt$aruqslGy2J22mdauAhC@ zjaQsaH|UYj2j-nM`|=xeZa5u@#pV>}oQ6zeJm=rs7>91S6u9IKD*KgfLJnjpbmS%> z+q0w~uXn$w^rbAd8p5wVF3E2aazB%opWvs)Zxix}-0KuFBw1`bkfnzCk9+$&EOVbE zXcw|y(sewUB|(nfF62=rN7{vKlQf54I^jE0*x}tmyANr2Khmz*6fEL(fD4aeJ6Zpy}|uAsE_Wt$1+c8n*N;c9A$5owA+PzR!D~s+Y*mU+QYZ& zGdr`C|1r(2{Yi=LenDv8%^Kb#bW}T_SMTral=z)m^IP=!Tb|-<$EAPAAC*+?_i1jL zYDnwb@c^ejx=YAolB&bj@B!O?`G(YP=(|Z$?$!3|Q-waXZ61J_a1HZJ*v)oy18Z_ zdwu(0mMq`vJqL*8K{=`_xbrq!`)8FI(5HJfWuI!%p&og1V6Rf`vjH6}{kLg+zf#S| zYGeOSjn{PjTKfSV+XJdX16pps4weBOOarPL13Jk1wRL*!pwZs%)xkNSgJ(bo@xa|u ze!mXp0UgW(cdA?(-*4sD*6i0-AF%RhFAZof^*^uAYi|tPuVFO`{kC3KE|qsc%xJ*KgH z`#APh9jHC3%AL4}RjKz*kwDvdxAsG?j)Yzv3B8)_A!{#G<44tw z98!(yR!h{b*|)1E-l>|@{qzanrP?V^oba7@!uN3rb*lmCR+a7040}{ThP6X_R0X^3 z{PK_;8a(LNcyRU{hK!7^&As>;@530%RQ{&OCgKSuvdRTjIxL12hP3N#x(viH9cIp5+sN=IwM@iqUQfD2O z-8y;f)HZ9^Hfz`6+M$wnYJ8VU)~U4J)>!lF)y_L8gYeaRS>uk}B19s``#ChO7Ho%B zs!J<%P#bgjX^~V1Np}}NbyOZcst*sT{DUvq@z7-%m3UAMYL}{Gm$+xI-g(0JNzUGsSi-uSc7% zN9)_IP2H{9*=w6z({*Y5K25hzhwZ*+MH#wOh+dr`x-{P|9hcqO5C^sEy2ML-O_L33 zF@su%PSwRh9o~bgt6kfqxIrB)z1s7gha~=>=Cf1N@7$^N-?h&&&vMI-?_hFV#XBTU z%@MVMDplX3lIxzAv{W5YLqn2>Xw-2nYu`(6u(j5OuL0>hm2@Tj@%)28Bv4Rt)u%^ zZNU!hpb>4Ek-bv9IB-YwZns*yy=t}h=)~NvYTT~(+qd)6V=}3X=``0aihJY^$@)%P zljoHgP+9wI@94N5mc_(TU13OT9eYwL)T4%Y_{kH#k7<NXhE)1@52(uTeLh!Qw?Xp0Qw-+s9?&}Pk%swVUMF6#EvZ`5EycXv zr^9$ud%r_l;IKFhFYB<|v70ORvYPK5+7CPQsU51tJ2bZ)qRlVADAMh)s;ahThpOBT zozi!xRokJ1eVew;&ihsBU7zDN`;zvvx)ahF$28Ls^|0>aq(}A%xnGF5bw|YhkIVDp z^868TS&pcE>ru7uQI!}`Rq4|z4r`r8bU2S_Lyl<6k93HK)^~S)@*C;5J=kj*wNicB zem$x!9Z$2kB5Sw((~qpGTOCt9gHtQ@*Sk z*m1iS+AmZ8D?244UGnVEW;(2j*{#JM(s9r+EJZvfM3r2c{D{>voz`@)_lnwmQ4MFu z4rz{V9gc@|cy_A<-I`0UYC?zV;bGN?!>S3}Wblp40_C{u4;<0y?_t~2?Us=V@#vi_ z_t9s$(l1*_YL^bXK9#Xg`@HW7k+o0jDQ?mcX@hYw3CDGA6<_m}hoxbj5F#dJTuL3c z>+XK53H^sS*_Z7CXJDHZ_ikl&<+p2I;-urUsyeP6F8e~q)lbwqKF2AKi547DS3}3X zBpH8Bv+uvfGFmm!pz%S@;<$J%{F@>q#<>rbWp#@ zl{_MI%n?=Iozjit(gNe!0tadZr$?*arK^g48b7FGeNd~k z)7nBUy{k*|>C$`$wSJwN-=NN%eR{uF%RQtu?A3l8)E*k#FZp$<1sv3gV9-t_nopnR zJFN5mi1zfbJ~yJi$H;b_Dd)!H8-?yXM_4<9$qw@z_l#e3xlLt@-e?67JI$8q^vN ztLpF773+}p@1Uye;E>MuhoK5$2h>}>^Crph9#y`BItbP4Tc}%g{;($R)}|g+Gt+C`rUC1M zV|P$W*e&anqaxu^m9SS#@|Z4d)B)_?|N3?E`oNLR9MjgmQ`?|p zKxE&q>2AqCaVt39Egsf#WX(S&c4|x}g0W6X)6=CTKA3+>L?2fdSk=2->)vC#$l5EN z$~*U}9Jkqg+SO9@=pa3KSX12e+A}#{srHp^x&FK_GpflB*^GJ~RS{oA44*~y-I>4l zr0Ue@L>oS=8I0OQUDhUQ(~YWu>9)2^yQfbK!niCskE@02(s9zM;r2nzf5_(F^N0%g zLO$jp74(jL%o8f;NM6uBRja-SG{X^_xLX@{+kR^z_DN@}4H;G1qhr2X$4R%fSkn_ZRfq)oL-ov%H^J@?A(LS(glRL0iP7f$%zCjxY+t!(d7HMx1BB5EXiReO82(|aG#q=S@{ zM7uoy%)t)H_K-SQ2XE4}2W{HRh>W;;x#( zmB*!~{X)cf9+$QDxHwQ_vZxr-S^The!qD?sHgw`qj;X;JvW|U!ev3j524B5fO4ubt z$MhlX?jhX)7?y?@QoSA0IjUX5huWn~af`>q-8&}!!%^88II0ur&{K9Wc3MVNeMpDY zkWP%lb|SJqkxuX(Pq3&jj|kCes`n`oaafykSS{*se%&DHU%5jns;$+lL74_#(JAb( zigNfVNvsPREn=sR+FMmEZc$I;)_X)EO*Z_IEhBr8M`a~^OjcOO2IR3jZpl(#AC)bYW6}%9v;{hDIpI53(j8WvJFJt)Vf6%t z9}|fm)nsY_5384bSc~bf8-xP~B)w)gqH55ieK4ZU)}u4Qh_=9pj=dgLml5sZ5pC{1 z?csJ!-)?6XwIe%q%It&K-B@ zgZ2P(TmIC?o{;a>ss8Yu6TT}>_-0F!b*YK#e&IDSN@KF}9Mh)j*6D6YtF}+Q=6!ZV zX_bZsrDe56J9SKS>g_>osV?ofgVul0Y!9j`4ywyHs496-b)i#xtW#U;;5{P#K^3oC zb@txJbH1%7d^gJ7A)T&oI6-VJl?M5sAddmwL4Yr z4wa)reZdZuZ;x8%!58HDoqcvVs45Lw$4Ltq6l-?$0E>1^yzXPF*IjDI_u18>mNKZF z)TNVLuMUqvm8MVY->cFdx=p0%)!rCX{T$R zY?nShl(&p_*lNPVw%kWf_~vMrXi+lGpvqi&vuC)(J?uqV|B#VSQk`1)}W{=4?ZT( z9k$x0@jI=x)%-`)V;OmX_5#TMkBjmj-+99K0mZv|aX;-M$~tr?tF8X`g*kTW>^lW>kB$SJRDZ zD~@W9kLoI;SM_*A{fR-<=TX)7Q61Bxsz2Q-@tx`}=su@TeA?7~wpzC9bR>@6A=MpK zp?Ym0)}W~27**ppsKaAaD>rHlhzdWd)@oGMYg9+?sG8}nJEgpX>Z|NK;VY4tonmE= z%Fg^T*`XPe(Ac1iDB1oU6D1v&&~cSyyAI@?c89&+PH_EdAiBlJJSxWhs0{F9w~H!l z+xNOXRA}#cgLLkd`-HqGL>u6+W_DP|*iIeQqt>q(u!h{e=`?DMquPv)`=!Er)YkQ= zZQc8T#2;3BaoF0in>AjW{?_~%mfi8*ts`4JsN>>6jmy!_K_tZXvR@IW9eMT$QRzw+z%MYD*2OZ6CB}MtDU_w^u|*U%6BA z)cOvpHQ1x7v{Tz>r;gCQYMJE#VocqQTeS|istxLuN{l_0<+Xy{+8MAXI`+M^gF3!D z2RPv|SyUWT?@FDKF4g9pn)y!6{2|HwVdj_11RlQ0~(f5z{+1EcLxdh#J=+ zow|qaQQOo@wux6>qkVa{cY+<=nKxde+6bdM#f=WLVB=DmaW%WWnyObPj?p2JyH^#f zM-{bCJFFdk;1)@8ubPP-d$!VV9p?Ug%i04Dyve8QUppjrt8wU6`#z*ouZ+hr9S6g9 z)=(4CkyjJzy5gNc$$7vYVc=~+E$cC5cH0i_x67h_UEzs3A63KGmw#==ZW`lFM9s@q zY4^?2L-z`KK^j#i)#GxIIQA4rj_Fa$D2I;s@dGd0a~!+_C^`2_>T%gbUp1UYaSdrl+~DaT&q(D+^$=e+shNH!DAd10n)0SV7*3rGZ* z`L(HNbChC~@rNVx+MIC2@U?PY&Yd5Lr6PDook*Lr#{)*PJ)MJ{4{zVVOcSrX-p&!EiiUmu_vOOybd| z2GIHOriL(wh0bpbN06fzo}lsic{%_56{~apaAOlnT(O!;Y;2;^6I@HW2Jle`{-4+8 z;tEm%l8z^vP$!CMrf2ZE2LufEZV}d zD8#Z7T3~*%KAE8Bg}U>TO(?_-Gx3K} z{XiIBcEq^-n<}Y(QrV^$a(2T_$@ILoiup}V@z%xJL?jcV-0(R5e3kQ(E{B$~2kBpo!iR*>Yn~)^PlrrC+3o!3^jAWBR; z9>cTl0(@;kCFco*4kFYNjZ$MT;89jf*FbHoK0>`8BnBf|qp}*6G)c5y32r8v;v`oo zu^F@pc#2MMirBRHzz8``Lu4iug9gTBT}X5}J(QzEhjv4oO5eWn<_Dw{|5pk6Vk6#i-e3Ow}@RYAG&&YbFU@0@IR- z;b}0N@jqpr+`MSHQm8G3jfRbe7p>9zXjs0lVS})X^h<@1VW7|=rBFo*H)yy)!%Nrd zeJBjy*Kh;EB}m^G!}olo3dzmVJrt>ZP3hOFbZb?*tcJ51UaQirRcW&t&Z@NQL|WG0 zM(xEbLW0 z=?f4hGlGQ5EYvA75V3RRLK=q-k48i`@$^#yrZ&YxjN#K1#1Bu9UG5sVnfMwE`VX%UcsMxoh6G0^) zKdvx23qhi(MKqpDDJq)c?3{&c$0Brf7cM0;>P8yannoI;G+s-YHsaGzH0;6#bgUDR zE6sDR+B+iDH`9oTM=@U}Tf|sQFNjf7Q6^D_C#-S}5W$q9A>4xsmoDVoSn3kJ0}Zuo z71B$J6*B6|B($2Xtlp{?J4=E>nTSA_D2F`V+T6@vsX9x=rDxI%r@SG4W`lbgu+9(~N?IG&v)yL_PO$ zDQZ!l%5p*!X{)WwG{j7BTzqQ;i}cwLBolln=4KhOyDM$H6ve71`X_}NH**F)7B*c)VSV);UYzazmg_&SC4$&|N{D`#|*(Oef zOq#ev1i} zaTc*HGi=MuQgWm`gHMI&X`%>EUlhY)CYFgs!twdCyqa1N1wrPuoiZtc#<->|e0T}1 zt0w1HO2t(oFMVK9ir(9w-#0=|*E=t?%{W&@FciARztWJ63UNxE&4m@%lU7s+@x z;&X8$;ODQ<6anxY^bjQTUcwX?>b7L25{@KVmtw8o16G|}aMsbBYS>mzIP@or@qCNv zDV2C+4U=m5mIO4CoLP-o4kuJ&PLebfvxeMIjjou8uBOGsEDggB7Cd~~7yfJs@sPKjQ- zi)7v~LKaoYC`cp0G-WHTA1s~-jy z67yzI&LbbE8KyEbkC?fXf54`bym_tQ-mTts3ug1Hz~CkCZgu3SPg z@YYf^K~Y|%?%YIm=cZCDUQ|gF^=%*ul7{$RR4kY)`vbvByTcL8?{y$anij8t=qBnS zv<4V;?xLG`-BSjN6>$a&dAI@^h~u|dNF1@7cpCN-5oH{q69~oPmsRi(Vq^5nFtIEq z6c5oD-myOpB+Q6^qgIs&n@CF4e!IF&S?I<&u$^H)|c&H3R5 zp!KSka%=;dl2bJMH!MZxM1e^h{u8wH{lo@9+ zYjYi4Jxw%YG1fv+GfACJmbka5kyp2Y^Kt9q>QQ2ZF8e*{SDcXdrLnmcu?=0ulrNWU5E=0YUQU!^*$lkeF zBcRN3=Mu|&$TA;M=E93CbBR8Ekv>hEE&TLF_UVi4Ll@haOKg6Z*jpb4L*nrOz^?(( zrjxr^w5X0rpq>pHk}XlkL>-g>hvDfU1w0loPCYx%OLYG`P;Z$fx?c5`$guHrzsy;} zonB8@cL^IAmox$vsvauir%gboz7j3%)RQ-eD^$hBm7Ed~9%>wqPV?}~I^<*rKsl43 zFwj_}r6`&N@HADH5@A^4*(Iz=^=ucHK-c{BUvx4U}<$s$W7xwsxKR1mC5dFWe>BJt9J7P%aS-!yX~cJ8F2REWs~4!L-5>kfSxd zFu0s;iH%x}%@a*ERZ}U!a8yp7n4zI6vQGMlEywz>OQhrLEg`ev)k9EJfN6YQu6Rjx zuDCwa=3i2cwpzk{g^OFCp|kaTAxw-RtnQ-TL`zsf)T?H(B0@J zF_>k{Yaob#L{nOByi#m{rZUo?ZhbQ~wzo7KiP8+;5XQ0|-QhNb<7iog8)I?E8CW`h z4X;oTlj22++W_~16A}s1ib1MC9NbT5DX+sD;Kow^s=*CH1NdDn{4y8(IAPeuMg`D`MtYi&zow76*uZ7%II5R-ImNaZkBM)+PiER(!jMOx+(Wv~YaY7LYJ1AQ4cNSOgx1=fhgRFMMw(aqXX)`1rN=6;0YfDS zR-XPRrTko)`cdlgJ+CW!tgLdJSQoRjAt`xa9$Z)z6zm-SD z1~w?;U8!;ek<&#Rp=V!va?T#Qb5Q6q>Q4W4X zktkNG)URMIX8ObsWL;f9NHXX*$cfU*mLjxf6QW(LdOhh1)8I&W(XiB;ZoVX~(4bAo za^S~0qfy>U2 zq+2eQInI{ZzZ|#xw0!hvBNkbf#CemJ_J+!q$I&gSX@Ph?=Qwnej17*gXn7QfPcX?W zEyBy5;&3)O$<7`P+*@dj4Y$bMx4H8ph8nAuflvdqA>YXN?sTNagy-4 zVDzXsG8Zxb7DD=sR({U1_rSIcuJ9)}n z9%te#rzydS)76b@M}j~LJPJZt5xt3y(m?n<8KzXwa_jQPg~=5!$J#EAwcYY+sOWOY z=_g^`xUB6!cx{It*%c*ZQ$`ZoLx?yzmB>06x2ruo%R8$?SSCUYE1FeD2+H%rSlhO1<%rrboCnLVA^Yx-PQ{H$Z|THisC&t_IS!y;2b{Ns4KeC z6}0?I@Gg+Ef-Og*TpN;bg&Jenutt_dNLV_A4&W-P28J3rhx>FY#&@{25y7vRASo#N zQy6kaIL5&8l&+wAat`h`#v`a02)*$VXiSKD2O9Ci$+Y?Ct`PNaWa6hKp1VRctC2~d zF`eO8*ZeDxwZ9RUl1BW%GFCE3>osPDCc-!gL;)+UFPTurO|Us}*c2haFLi)WeLYZm zD=r8s1`075df5drpuBidE{)Dl)TW!-T)NV;^dbmKWJ+p)MH7WrS_h04QMBqtjJ|n+ zUvK7DFg*O&H2JJ0Ou1e0G#>`9%u8`A36fM;fvc&?*EeFch(4WAZ<|O#NJ6y@+;kU=}*h-l% z6Fgsf30Wq9^3!gDHQGt=)?0!ML0N)qvi3$9qVj=he5Y`Jn8vpYW00X#R9u`=3g#;s zXD0_y)Q(Pq=57e06($P_IdDasSZSuLl*_5=Zi2^maAgvwb75%F^p(j3vv8xe-`$lm z5)(vne!LKeJ|P3^@VjwSz~jW!zRFQbL48l*B=F*dLuDq;6w44jaZE!2*+;CftU5ZB zmEF6iXYvX(Z6ctL&YFlR@VRD8#O9x!IuR$zM?&h|LXWGU3>AlBChs{>)eE+ryac9Z zjO!AnJmdn*LT7`_G{X`pM=ME*!?q-4O)65IceQ7}DTaMw616ayRvx{FXi@+Yh&a7L zb){gw^5q&Ksi}F0E3CH7LF;@flDz#Orib4=j;R4?%uvNJQna$*w6fq(SrTG3UOtH$ z(p@NAKBQuwTo6?#8x^?*@33Q=D6c;BIQusfO-H&gDT>>UGMyBwg;CSX;a(M9jG`qf zwQ^yMCZy7BbQ8&dq^G&gx8zY09AP327kUl8^DG%0m*8k3LAhbYvZ+p zBrhwEB#@BiRf1V<0|`{YP%?8=@v=NGx$|pSloaZL7|21hKjkI< ziM(G%37S{~DKFw|Uc&Q}8Jq*AAYrN!M^F(NS~6C^A(U6UX?lW5 zniQt&r{-h0?J;yGM^GC7O7g`LxHt(q9uD9dB|p*w!{;4|W_E@W>lU#O6G*HRXC{zn zwlU2T<0hK@ezMMD74`!b{TVCl4)B&!bl+zC^^aAv72Py*j+_CwK)#q6oEr1 znQlU(9p0jLWQRJbm0xAwS4%46;*XBd{49IwfuzBE$>f->(r;^$@@mmQbWPGoYM*5L91>q>+t=bdu~> ztkR=~q|#N5@Gi48oP0_@{x4h6g zH6Lx?XT^s*^va~C%VYm4w1A&>>O35RQ-?Z9-u%Fo)=xpEIOE7sd>x9zRRWD1Af?5T zR6U=sCsULYp3x74@C-V|pR9tMtHhWjiJ-C5^Z`lEOEPT>NSN~C2&xyoXpV$B9^oqR zc$6?D)bSWV41a?`G4e5nFkxD0tm0#WBp(wHPZ`TGL6Y8nhp?+KLGp}O%AD*Kms_4U zVW&}OHBNF8_+vI{@^2loW;wcs+g!TBiy@*09<10yVyH||Xi3Rx5P2cpSuP?3yNRwYu4w8&Q-i!`>@_vu?F_X2 zYTWcU;ZlnC;v)_6hJ({2iLu2`FNX)QvkwMa4guom-3M2emnB5xTPTlMa!iP_k|S{z z8-4r~7#J~5gHlUZ;|?!g(Sww#5%0nZ)eN|KIIBzxa_~1nk1AGUFk!8S7k9!WdkOzR zARb@tYEkwk_Nm<_yp(KE8WE}^`q57lr`v?1Xc9xFPp64q7RMEt;TFBWTSmk#Qp+iT z7jfzJUg{m1T-nL0u&mDfGi|ugyT~W1Ce5T)py!bhXPaLMmr%59%?YbjN37_`YWdg- zLd)FA6gq|oWWtiuW*@SbNftFB9SN@1*SOJ6sU%*%A#G+>3=Xr{)gT*z1jwiiPvB)| zeVu0_K&x})o@}BmI+V&{Ap$!hq=Ktu;5IRFR@28;j(l>}gwNk-l5(zQb=<_(bdz-0 z)zV>`m;~_lG*`~OS~AxxsJxfFkEr{_Vv2*p>Rn<8M8(#Pp zf_TV90mz$@!!K74dDhr{3xxR$%u9vwH>A)ssr*@(yN0(i@CYAx5kZ3@A=bfY3Zj@F zbGVN(C>{g_u3`J=$`py4WG#_6B|1k84G*St%7y2|B_qnmUc~UR7cqS7MGPN%5hLxs z1{@uGan8hWJ~Y3k>?e-rY?6YuE9ac7gd%dmZC5@Do|2;XA@XlgdMR})Q*?4f z`V}XCE5&C+q%#GFL|#hvro5D%`+&;8mvbM)V<y9PT{I(w=Or5o3?6VwVt=ExPhG*?4qOG#+l{H*hc-<~sJx zMy7*wEtl!9!kplzWv`o-{pKob;Sgq1=jn3TNk=gM;!2Z4l{J3|iutRObqZ4RdIeOb zZBRTG0Aa&kl8)rtEiF^O!!NZXV|sHyj!Zowv>GN#<W8j&3k;1651qGr~Z+ zK|UmOtK{Vrgdy$JD%uO6x5?(KE#im*<5V)STTsC))JNUpX`GhFgFZclW9;V-_`{41 zt!VECI;yFP;q;K&Lui00DK0ZGvyM!gxbhC73kL0m^!%|p1!+^82zrBpG^G+jkSKYY zK~NnA;6$lCEJRqj`32;K=v!JdSEO+|6`yF-0K(}8v{*^H(Y|@^>YfJ(J>sMrxnmmn zZ50G)8!u3`YH>9?|LJ61hG$G#??6EQt~Nk~M{AXg*0hXP?4q!PS}F{`p6JTfiihvd zd8>dail7KS3uB51w`vo=yT)5E)PlMdQ^E}D1dC!>@?((!HcK=i?bL8W*+=1ob|b~X zFs3TOfg@KN84EL0VwO#MRc(qyR_W%>jKZK=-KjPX%N`bM*5n9HRxYvl1E+jCl%`V2 z+XVySrKKO;DzQRoCIP&Vz@q?+bPpIr{6$%AY20$sv|k2! z;lk$-Xu5y`O&3VuLJnLgfr~hB5kCoaro>!#`2rMu(PYp(oEdEzQZ~{Pc&C$=7%1B+ zBC0H`R+%1d;DIX~WkZ~p4&w6N+@#&yBnBso-w&aA7o9633Y{SgI@b;?bfK`)(Zt*C zR310@LG8{at_a6SCGDxpYc6a*TzNd0j$vyS_0gYbLVc9;comBIn(2J0ZdtZTD@@Z%RzIvQ z5k~q>zp?e!>Q7Q-^Atmllv)NC_IX(i)Nrp=YZu5W<7PRzM}$1CEUSOcS&MGZIa$&G zmv|Z&OoCba;ccK9riZ-IvS!-w)%uhmpfA!>d?HD<8j}%Hr^MSL1`?JMh5pfwrQ3{( z6G2BwQr?B3ymZkpg;;i-c=oI)48lOk?fm2_wtUX!XL+6;<#~FN7vOj_o3oBS`E~erAp*E^#vT~9tIhVaBpf*N z9V8LPMGQ?G2!oVUDF21}6dPL3du%gou!@#1Vg5|K!p6y*)kfjMH<+AtY+ah^>ha+r zQJkz|9%Bl-;I5Nl+04Xirrx5v)P8hVG_09Ppc#+yVwo9KnPS*s5{6>dY2yT&@sW00 zm=<-{sI6=f8o=*nNDEyfKRD(gf_HS8(p1zE#rK?$!?}iQ&_Y-D8j-YxiN6K6{Vk+P zE!cD9k9@8XVOxZ3=4F<*SqgPG^CHXJET5b^*K)?2xoI}*ds3Ulp8Bsv&HbBk@iyx_ zP@Bb3bT{+MckX6>dCJ=?r|wJM-A>SnwC+pMO? z+brYN-7E^VS(+#3U8l2LtIl!~Mhi#;n&>+I^+Fe6n#-=!c5fBxT*s>2ifhi_il04k za6ubi$4$}7ZG0Vn3+A@U$6(h<#ae}2Ct|k>xsGQ%x0R;6oYTrijg z`Wo5$Xyd()p#716Hn&D9&?cltD$vHnX=|a6NZVQx8|Fpulf9Gvqn}RwIFRngC0bPD zGetGU##iGv#m3)JRO3XQ?L{~EYup;ICSV-n8qWkw(3ITc)&!#^`%6vf0bflSb7kPl zqf<<|nbJ|T-B(iqzQRmpek%BBW;*lJz`w)HG_yK zR#i0TUAY;Rc;f+I^TTd}!sI6tZHucLqM>jtHqA4wp-eJFMwM?yL)WfY9!jP{ORGWY zBXNA>mJY!Y4Mkvl!m&gsfoiYP_nKxr2mn2ToOuz8}Y1FlDVb%+gOl6XY@BUL-?h(EVfoc z;m}3rXJEpjA-wEMssxuH1ZO>jV?EMJh!jod^T2P#;RzfE(T_ug@FN8&ys?K=mrfLu zO~fL2YkGYqxt>G`ogbPH!JC>W-(+0~z9!ucVab4)bSNI%7!A#SedzFP)G%KTi{Hw1 zu}R?3@DH8No*TLbU(rGg+RKOBlXDC;geS!1H?XO0h54NqYC#*Oc!)*tVQ^Ynv@w~^ zpbZ-FGeq&$^Qi;!(oj7L8j^xkJ+0}blPg$Ql-4dUI(1?`*U56*YEnzQsVuWz@?4*a zQdw_peY7uLKA;9ZJB%+|(wRA-aH92}6a@7NQ$_I;T50^ogkjAJC)l=3(w^42`5aQ8 zf%#bZ%YWd%U&4kI{jwdGHveUppBbT`{SVq)xwXx zVTz&r#VH4muAJk`;r$phT%0SO`@x)Vb7~46lS>7-T*+niQM`QJl)8LbNm0=s5mnT7 zMde#;=iK#pcL6$?iLU3-vOYhQ=3a*1sl(ys<#Y2nrAW?P(OX2PUtq2R(z9@>C*jMt z`nEvu(~52{-sC`NU&;@mMLaLhvB)fK>1Fs`)C~R3+~qNdn<_<`wvYcGikr`>t@Moa z*;kx?{Tb;S=d?LzpOK!E+64*cOvhF}W?K?F=cRFC5H+cjDB#92_?eenFpA!7iDepc z`2I1Gav=*vGxbe_phk`%L{nigYC`m>Q9ii7wsn0Seq$iBK0i^_%;YRczV&ph!aog@E6Lx_ z;aiBtXbrvi1NRz65qoHKEK)Otb8f~|2g8%bH`4V9Y-njTj}$7Ozl_p>Q!^zMU2mfJ zW*w$BnLr`1K>Yg4o7L^Kf2v0%=+E?Gv`^6t$LAD#zF_gJ(o$bVvEv4PK{psY)#v@A z*efo6k5fFg+*e*a%Rw6abBOoPDxL;@MsY=O7HD~K+j;*xT2X@^NlvCyKS$}Q19bTs zT|SS?95;13@vU@uFI}#u%aypaoq6{4mtB72mNTI{@4LaAJ8#STHedh2^FJCszi$5d zi*H2uhL&^Z&6(2{pmb;6I445m!v069K!4Y4A)sSod16@j z+nUzWghhQB3csC!n(WPB0?V5g-cZCI8isCxd(+C!O*oXsPvl^7oN#Y+-k8f{_=I!j z8R>a*{JB#X;)g2cFRZRyv%Y%OdYT8mMk+v~t;m_-Ydh!dI`Hiud`rVpCfu;6g4t5E z0S0ovkD3+!OJTDn|F1MFIge7)|5vS=3c*m!DbAfTsZo)MwrT2pxSx7IUEXA@PcCe@ z&G~lQJJD{_d~I|7hjyEIZc?*RljWQ3LkJksKwl68`{oU{DDo30)%!g1S|=o$bT2PGH*wUQ2k*tOm#Y<@T)T-} z{-^dWti?p@a$^_VI+NOEp4>+RNHAZBSXQ#JZJykM%M#$XC?nB14i3kn@wyzg$Dm0y zrQF2p$qv?(YZ?x{Wu%C*t< ze16c(Mu2P$jCj!o3<(+_TZ&Wf*;2G0g9Zj2gNb~ca2WKs}`)FXW}@QbtqI% z`$o~!#1oU#;U${$3i99uOQJP|KfC~k0ipEdm?gZO88!tL zL)*0x#%ukXyZ=(EL^XcFm|H3FHp6E^6nPfIERCAf#WGk0Vm)PTp7h&<^A9DTg}+`= zxu$CV%0=r}ty#YSQ|(oi)$l%X$})%Mf%9=0_NUGu{ybc2PI_Az-#iK`CUk+?;T6*U za#Gz256+b1cYLM3w$tBczL@;n{{@xb2cfGbZ@2t^r}C_k6TO2z`QKN0HkpNszEFW8 z%aRW#0U_-9{}at6$M~NK!h>YO{Qv)^hNmr40d zw;Ofe&1>M)0u8+6f7HOY%WIPN0*g9fh^M{95VP5xjznwd?feM#Vsu;2?h#CwS@aR6 zSy~#I0)H8%xxh~FPLJW==*NyvD%lt^c&B-86yI^1=-Eu*n4A|n3xkew#w!6jS)DZ} zuZP%FWUEKJP4!9m;MhHa>7#+o#s%94IGhYMV(kTwKWu2@Ds(ndU|%XdG1arU^Q#sv zTZSE_G-}tHo)f}J2wp^>{82~}k4KVN&#|ca@}oF!!)_)`5veHLq%i$41h`~y#q{JV z)PnaS>ZL)#p|#bE&;N){HTg``vev_iT0Xye*~(DWiuuczhn81XW33RX3|+IVdTD6> z!nM_v=Y`?{PNmCfbh(f&b8*R)@qSJt?RJ_JRkUD~UqHc& z=yC~NCdNB+A$~v!BVHRxY$?fDc)b~E1y+d zT=b9flZt(uLxkF@@IP7^e;i0J#bweFLj@fubogoyc|AURTjTTj~|VN7URQ3{2U@V9=b50 zy-j&U4g|v3HpV-Uyt}FI#I9W(on~T~VXVdT z_pLxQUTO1`cXL>`&n648F@e*2yT=lR8)Id{8&3G>5`Gn12Hs_caQFiW$b&_B|xw!1WT}%sqGN?5(rCzcP0YUK~WTU>%O8UxbHje+A`H@)!I#KZ#T8Jm2O&X zZA%sY_x;YjGj}G5V%0wNubC(Bx%b?2&OPgQ&iR&eK@M2TI&cnAGM+}_CbieUU!V@d zNH0sb`2Kbri_r(ZPw`I@*;U7n|Ls)L5iqXA6NWSp9en7JHz!h^_haYOQ{z)702~)8*(cG*5kvSuE^bUSjrXWCd#IUET8+po1;XfM_6Jt&3N{ z@{jG!`3OD0tl{T*cg$of_6JZZ#R?qJVAq6*v^v2-l5XRpf^`ybZ}IlSc`o9zblup7 zy&GKL=Be{4FlN0!USotAZcHaGz^o1~jm?LgC>KaUwq+-Bn7J3?YTrPRK9QxP$Qw=t zbK#|X&JU~%XF_605YnZvkz(OlSVF)EBvOG?RIe+r%ZhQAbwm(;mH3YfWkBK9vp`EG z7ki7FO^S31>nwXw_tFW87H-tp*SnXR?vUv2)L~Z`I(_2~G%P0=8HzX5yz%9YL2YDa zfq$SibIoh#>fQqT7cX34GX;{+freG00EUEr7l#BmO0mf@G6uA|y(G<)DB3C&LvV17 z)I68uz};CD-#ZfXeA`kC15gIMmMeq_B{3FcGE37F#*E?ARZpT;zYO#FvibF0_WUtM zDg;T|7;NImqN!)FUEG^Gu2||?>ogm6g@sq0SLQzJ;8JQZfeV&*sG?RV`Elh_To;f7b?PF#Q zE)AjMXjYvb-NFn|Xqu8dc!eBU`vG?k-&g_fp>1n=hL`i=T*0LtL=TvU!NUMeUfjXz z?XpXXFi>A0H3c8CFtxJVn*}IHy$-;VWIC2$k3haUD!b6@e9_BB>40zT)8RYP$`vo+ zIAAP$q=};%MmZSsB=uyLlw^xDMSWr>s?g@wqcG8Nai505xfh(1R9{lYQ;fSIS1y!) zfRV;6u2&y^PEaBNh0xA~nb}q(z^rsLu&k?lF_s$smHF0+273a%u4qsfpWqDQ1UsB@ zXZIrR3*aaVfvsTAc?sgzG*Sr7p>*HqctA-=QyK+WU~E~P{E zAO;`Wr`DVy?wnevNC&3`YlAvN&AOtE0%x-rbGGA3aw)`jkgO^lPqCSC;F``u&Jd+8 zz6doH_8xe#J%#XjLL=co!T|thSl>b6Tezzf6*~-56FZ`|R2Ul=IoJX#6zrgwHQd71 z+=_;>pB%6T`!IwGGyHhW@Q~S@-l3`J;*QUq^>sW? zC@jCR_omohCxcdK__qqU^@T}+yJU<&k57(WSw}nOljaN+sj!t_Lz!`y6 zm0&Mt_9q2eV8(PKgH0q*wan`#Utm0|t-Om=7K)c-C#gk@Kr|YPTh&%9JQ)AxO1sRK zXwdV48-kGB%I?so0~Hc1VXv_Z@qaS@)0+Vl4pQwTW33L_BRHnpF}5@4L{LNtE{fQ* zNd=5fn`*1^9{PdQag)fRkUd+X=y>$ARPW8|T<42@jxTlvblrIGkA05B%3_PgsMPf1 zh;f%xX$W*LH~mQ(!sMVDA)b>#8UjL2H$=i0VlYCyDch8W@XA>;B)cBc0K*FKZIZb$ zq{bE&R<+t+u#v#}4+~184OY5J#3R~mma-OI>O_8G$&RGh?IxJC*gYFu&9dD*f~0&% z><=_qDybRbS7bUiZ=|?tW037g*t{hRCmUlo9=p$xZR)vYv*)q6Z6ljKO?dTzN9=>q z4UL4JF*Vj+4T!}=x1e8mUeIX?+1&cs_*{9w9*Su2Apgt>vuHNSURh_hC*$!NcH??H z3{*fk5sX}m2?a**4QU+H>GN6o^FgpLlOe7Ol#myM5qP)sQg+3KXo?)P(urfo)u>Vp&l7euYzcBRW7E!5zkkmm^jbN#d~7C0dbWr?e%z9rM~NyTqV>h zE1^Ccq#9;VycZI8iDH{u)p{-3@gSV`Nlt^eh{q<7+J&4yNpi^Za9JBz3VNNxNBF=c zBKO04!tU%*DQ;vi7h_Juw6EcTY7_WGNLzb1`C&YNi)j`n z&aHXbz?*pAkTLSo_q?uF0f28UUC0<`^?}yae8xXFV>EQ1w*W*wgO9$FYpV=4jBOki z1QiJ%Uk%Jr(W$jQ4E;%$NTwfZXnVeGV5;Z&z!eDT8bmOWy zLw9L!Tb5Xa@24w=i!oK2QSy?OHa0(Uh^|B-sCKC?9Gzl(4g1)aD0_w}vaf@fdO^(v zFbq2aAPw^`xtM>~A81o0(B2k6jYa4U3H7l^q3mIV-AO^Jl#n=~C9TUHe4!+x6vl~Y zww-FPw?T_Dtz-u}ds;#VA2Nb^5;WORr4Z2QN(_mS92Mu>}JBIo~eco1OTsbhtl?tnF#71$gf6B`0P{~q}N6uA2gHIIe! z{~d>$iTF>yj2158?n4b;!fS)c@O&&2)>+92T=4l7qwR*%ZzZFK%Mas%e+kS5APtDg zTj2H&!Bu5jT!zXpl>t<#!9XBct)>Ejq?!rHCt*miqwFM~lAYz#P^0;bjFequSNSad zca>2xT6U8f*tr zOhl+gO=XfylF9f@ktUfc2gw&?nj9>L;MsJUf!NJ5Qx26c$}DL?%-M37d`S+6@AmR# z#F!&V`HCDNUzM+6oj3*Wnv3VHa-_@?K^l-T6n^b8UlzE(4l%!lvIs{OdA}*RTH^j@ z2-c~x)b~3IIkDYeTFh?_K14aE@ax9a*WBOHh<~&!Te~W`jVzZHl9jJZPFBh>a;&V9 zaAYE9c4ia)DeZ7s-M7}BCk`0oVZ_A_dn0!YbmnY=A@}xW^Ps{h@8Tr2aKz=Ack{`>n@|^rco|m7B zBR`X$%P-`Y@+)~kUX+*Q*YdLbMt&>5lUHP;{9gVbf0RGTpXF6~P5vUUugxZhpf|pO zzB#mQsQeYnS^Ou5;reg5eiPT*whfoJ<)5-ijZ?PM`FXPgb5T{ypMuZRb!4*7G`eO7 zG%_LU3&sE{6)iGhbqAZ+-N*OmQc}q>7(ig!X$-6)L6ae#Ez$c|l^YV_bQdfqeQ9Kcfu(HF|AQdDGCOd+A&V|?mr>ddx7}L9Lu=^Z| zRhK>iQzHOFlS(Lc#d0wTVbzv}=KbYIWplCgONH?JaFvGbPsrY2!b=1zH!sEw2v^ZF zRFG%vZn0NR1(C)}N8JFk8RP~jyn$QbmTr7#(hZ$mjCy4n<}MQwlU85?Y;T3KQ*B}fzeB<^rOGFv#fxi= zu@^KajBKGOpGrfwNEIJACzf($F*SMT*jQ00T zWj&YY%-v;|CHUX5@9iTPd1rAFisp*6pppSDhQI8tOsS|U!d)CUo}G)x)@@snFl=2_ zodfeN?H4sowX3k$XfAFevn?vkBW6W|;V`fH5ACrnVHkHsBM4<>N0cm_3sSri{xsQo zA^hti@hn^zBNZA^VUcB)d!uj_geHEl*P=D?%1~!Jd?LmN7TVEVXtk9gxA_E(6T(%y zgc&vmE;a0;arFsoOO3lSbkyk*b)Q!BecB0oX+DL)4E0cA*{@87HYU`}uvRZ!V;2dT zuH+354$Ewg?!qu2GbOV^m5H!eHzcXhh3oAQn@Kq(WTa$6qjp)YHl@a7jeL}vn6WEj zgE~WJw5Wn$3(dJSF?%Ha!Fb`=a$??dC!ATav<(6(S}@mywRhm7QRHRtNOgS2RuzMb znt>`{tfrk(YDrqV_IU7FjgS#?i8xI3V7v!+=ituZaAbEVYh7PN@NY1H=4DExjocb= zOQ0=%2QIL%Mr#}E3VSERp=bL+-k6|Rh}V=fQbNInHtuP}1VNTcDciXTSQtU*c9=4S zGtr)kTo|cEauMhgQ3yptr%;ww9C2(tkWOz%?enqaVBA#I;epOk;XtN(#SIpizE&VR z`0&6SN=Pb>sbCJw)t-Sp_1)+Tp=_=(0}E24KjI_m-ufJq4)<PPBFYO?Jqkv zHBX*7Wm@w=Eh%dBrl93JYj%n!SvR%#v`V!v9K|H6eD>RRJAEpfmd|TjN-cQw#694X zRF)IVhi<33$oj%$DH#Q8ZMzb>O5`IRVZ-j+9 zvygwoB6$l`c^CB0E+ze(yBTLstAnz5Gz}{8XDVz}nj;zbVHM3zC zYd|%%&1AD{X)W|0sbuO2p$?dUc8R%KAs|Q|(SfwP*IL?~v+Ugsq3Tg(#)9uepDzfF z8+JOTFH9YbhY2ib9|2_v+=G;aQN5Au#gonCt#wS5@bW>A)uiDH>8Mt^(6?uiMj&8W z$MVfacv!6Ig4l638p8KZl8s`hO;(+*x9mBniRPM!6U9OUA)IZvR%&UQoobvut+54E zgY%8D^$k1Ts6)Uc-egLxoXXnJP9w^4HW)e1f#`5+IEM4^&B0Lo?O-_gRxnD%i0t;I zO;{vueVPqw>!#Tz;38+G!8Ae@!$KIR>8UBU&KGC`Q1}s`@HoSzJ-7nu^!&{UbOu4u z(ckT%hz=vJsFoBW0qXvBFLkP>tJ_4{=ET25`$N4(m(?D+62);M8mYXbU&o`9SyGO$ z0LT}A;HaZ~AY@i{cxf3;9fR2xZtJ$YlHrCu8z*nF67Y!VdC~M4+sNnbon7t8(AfPN z`0PlYX0Okha2s8q2XgVgVISU0E0>;nzbEgf6z|94KFs5jlA(sl8W^$z=ngaRUK-dO zM~zqQqqpXBq560~#Es~OZSZvO275VcFPM$&vV82mQ{c7l6b8`Gf-?Nr@x0X|w)Iw{ z>xZfJcCtP#6ohfZM?#v&hYeav{d}T^-HT!Ml^M~m@~{v{*yO*7`DbN@dFGRjgqp+~Xw1MW#p4u@S6r=lg5rsa zYZOmXJX!G+#ZwheQ#@Vq48=1QzoB@R;@OJlD4wf$p5pn67bsq+c#-18ikB!}s<>A1 zGR4akuSkZP4x43+NoMWP^L`VIP7En@5s3R*RmFkPOaja;&8N z89va16L#ShIHZVBSGUPJ2B&Pyo>60~EzQArmJD{aIab!O=GaY|5IWXDlMc1_|UsCbj&&5E}u-l}+;;_ZreDBh`fm*U-u>lN=&yjSr)#rqW>P<&AFA;pIkA5r|K z;I_zT5fD*j6G1;rN?UsC+F;>(J^QT(mq?-XBA+^G0_#Xl(iQSncT ze^z`|@ioQ2D88=vhT>lp|EBn+;@=hjq4-b5O^W|gd`t0d#m$OaROjcV<8LzVs!Md8 z_}Dq_?d7g}jqCQfZm$M=a*ca?o8CU^J-yG|o@1Pc+&~w(?!~UV)^#s)-F2>euIrv> z-r)v2VVy~>*L`}wxjol74;$xRbvE=E$7FJYiMZiP<9U^Ft~Sm!#<|uw*BR$}MENs|Z&U zt|44YxQ=i=;ReEugqsLA6K)~gO1O=1JAq7^jdv36BHT?_Pq>G0FX27{HSjh*KzNYw z5aD6MBZO}fzD3wT$P>Ozc$DxM;X8!K2~QBdOL&s-6ya&Y_Xy7rzEAi8;fI7D5q?Z~ zmOw4(jXxngPxvXpA^eQ+bHXnOza;#M@B-mQ!b^l-6J93#hVWa$?+C9DHWGeM_yggO zgg+7fOn8;>8sRU5*9mVB{z~{8fpYMTe<%Ed@K3@f!oLV_5#A<1B@^r>Y&bY(?6U}m zVg$kCY+m;ezGyspd3`luCOnMlRghO?E#f%jO#65h+n4Y|s*rvJ|C8~b-U$K0^8~+3 zg1x~W3o48uX!`Gz2}*dibv*ba>KB3Ep74v(kM@01u@VZ9Bm1wI|b^P`S{uzqDFPoK=i5F!V+63=r` z0*LPm#Y~9TUpp#y)c!e~iizj1XbN%g{$9z2d!PnDbph%E>%NaZfrUuRy^l&I)5t|v zMv#Jghb!cLQSdCw#tstPMmHUad+A73Pc=D;*tl1>l1V+aV|j6p?H(V1gG&lLqC^`k zkOlfZ6w}kd-4%CvJQCkV9$(DlR~@0)NA8Gf_@!~!sj*vCT|&yksK)6x)J*IK<}$ca z@r3(F>vb>;rnSs;)iGeS>d%DV=#x<0^{RshZmp`YKvk5dy`;No7|5d# zjnJd;KBiG%P`WkXJ4q5dVx$8pT{F&$LdjI~6lF*)>BjkXC8OPNk27RFX=O{Z`A2kA}=A)76#WX@^D5hFj<*5Z@GJDTZ~z4-`CI3z}O}C;k-t3POd1l{KWBL2T6yA#w4nCsH&c&K_FQS1B7U zcFY9NSSj>%eAUJ6{>8rTm8j4f>3Y28HqtdJuV=@ZV=O54^@dD;$!L9gO=1qi)0tYS zVY6D8)eI`KuN;2Bo!=a5qeQPwl+UBuszyL}7+!78ha53=+N_q@sTqe&pFM5ToY_q& zaMBNHn&oUay|F*<9m@l@qf{nBnl)$Ez_hOvLOE*cK-~s9=wxKnVCkVTk`+0U!iH%9{@l0eg#Tufsyaa1Bu) zc=iwzhHxCH=FCD_gfX%5pFW(Uq|% z4@SkR%?fPMo>#N8>Ul#Pmx5V1H6w6%%pgiYa9EK!<=mV}TZPkM7gGlnY8ZOpt$hsp z`}Tw*0Y(o{11H&M*i-lF}Oxl892+VXEz(M687=|0g39=Z16ii2P9AFsg2*a#lo8uAq0E3Vq z4hDYw`?v<)e+_uToS+JI%-y@;)`s1haR13L?^Z4fwcb6zX> zUo}up>AW7`xdWAUpy#Fj=C0JQnBqYG?|sf6IHj$5TQST>@9N!4Uf#ln3iS2;?JVFIg!A&Qb{S)$vLDQVWySnJiUy|h-btcS%|q8M>3tp+ki&8Zr4 z$e!*|bq^n%9s>c51PJ1+fCX~MAs7aGF%T?r$T6oykUt>DJ|>stIXCC9`F+*R;gFP! zg_0R`Rdw}ORbPGey~`dMDJb|o`Jd4KVp>uDi(ZC*I$l1-{#s-o2X5(_t+#m0m!%53_Hc9&^pa7u+!{qwBBYH*;zJ?)){t*S?pc3&hlw? zZcTfs3X>n_6RYp^tsP}s1@4(erCbhwal2(NyPhAk8dkIGHiDMt`j@S?-Ey5RtLX`= z>vL;kg}WB>TJEwH@WzVecRL+V1eG}RV6M7Lw4N`kvAGxsfXqEayKt}i;QoRwd@jmb zJn|X0yFshjbr!vDCob0O>sRL|=^wlg{6TM8NMVVD&T@hDR<;8^;S0lBb zi?kik0W;{4mW+RKfn_5VQ2&naCNt=J_#>8Mrju_Mdf*U1=UJg&3`)UBq_2){V~%9( z6UDu(E5X>-zo|+ui*b{HEfS@lC{Gnu>Se#qx`m{^s$9i6(@Hp()8T2XP;$n521blV z#_Ilz6`Jv-x-~U4=h*A#430$#8{ekWz8We0i5;bWd0}Eo37}}c1Bg)i63J} z{%@`-s{B7i3A#*T7gN{;C`13JimP2EN}i+@iZBCJIcS*L>2I72JlK$=$}ob0sUtQ zo0sZ~|6rg&c{=>pA<6K&t$<5uX!)LF2P6m$uif@st0TN6hqwJopF=0VIl=ZCk8$J65n_2bRk@^R2+Mmbk??I}SiNt0eOX9(08}Yt4Hu|HNVg zDfKN|aID&L1I}oyAJ{Il1+%`rGf204lNQyYsL?cEo=oV_>u}F zy2_dFiz`9fsbDJ*-`J#=pE|9jSa&wtPWZ{3<$BN;v^?!%# z+HoturnjsW?sO`GG<9gwJXi1th_mvY8fSSRI1f+U^|~&z=<5(Zv04c$vhVOR7SvP2 z>pIN67!VCxZPH3ueqQ8howt(t_V6E?GyHJS`A1J0>w?=X%&r7MXErpb@@K>A=VttK zmg9MAzU8#mxMf>kKDu8yOzCtL+qLdhs|!}cX>m8Ggq^2eSF!<}BxzdTYjevBR=B`y zOTrdg^kta`pf!gIZgkrih|R9FKq>0OYL_jrfYk&yB_}cf!_b2#UI{-sif^;!aMy10 ziuDK^q$4BtwVJ|f%N6K*C04@oRk1~1F{@+^Ys>43J%-+B1uI~MyJQEN+y?V+@D3U3I3EbR!I$jDTAY^~s`Jf8&FnyVz}jw=i?L2eSsPih{Z^x%2s9?9 z)2`*xJtiAbd4izU?8HVY`8mJaXmB3`d}xdB6mc2rfB#c9`)t|iE<5~LXKS6i>p!Xd z{Mr51(lZ}Q@=6ED*vs61w&Y*?AXQtu(%Fj5y_b`i#1|+Oqoj^%rfRAM{0*(3YV`ku z_6I|!K20sD)9R?~JFU~ZsZOZl$$O>*h$%prs;+5(qW8<{XvR=Y%vn-(Io1SF` z?_~oW?t>m>SF?DGX6lHLBLO2~*#81gW`T4yX=f=+Qju|xEr8}HuJ;-ZND=EwLqUXx zh^5A)x&pP~a6m%RET400#oI{KqdXzlf_;@BeKdDS;H4drYQEtyC`aE)4MD{st*Q)J7V8 zVAlodD1^UX z>@GDN+xIQ6DbFD3PuSc}pt+ygjzk15OKnfGA)||w<=~N!o#8mHluus8uw)c%tJ7+b zt)V4JIOwoa$AtujBxJb-X_GVW*~N-gg$?4+iQEsY4LB#n|6U>ri8M6e$5_v4w&ZA& zgLs~>(*XrSbf@PQ9-nMN0H0R+(hBILA~2FHfhb5P#*bD1@JVa+PL~GLEQ%T)KTOz4 zz0=6hxAaGCifQGF#BT8Fp|&E#4HU63T34G7P1xSW>di;h?^H1hsB%Vpj7nTU5ogH= z9l>O51&)Nn>(VTNg*O4Zhn95&twX>^sPaePXaL7M^S8w(Sm--#AHTyS8cElJ@da9c zK7`iv>(EL--vp@~kh*=ddh-BQQi#d^4T)$m#fog~*F!j+c^ys!_$C+?fYGgcHy=H^ zb5|lIZVV8SC`pAenqt#fv4!BxzZgR3o!23h!oCSkC3$q!x$4s&#ADNv($u9^9F)Ce-@$hp2@x4y*mu5LU0JRs#DbI7yzmbL;-=5gITP zZ#aKFgw5-j34m{c$`}sr%lR+nA3mACa{C8SDs|m8*V}OG3`>1Ggwxq0=Qa%aCP-z0 z)WY2BsgqCHsMC5mgvaS4cnrYi%cHSbual=+ug8UYz3s6sR9ihR)$1?1wv&Fz)$1?| z^}1A%;un}){0S8|srZZvQnTVV6?dq(OU36@>}!L85Q>lRp^e8UFBh(9&dePCOPB*G zE>irY)TKh7L?ckP6-s0ERZ7A@rK_aU!`~frCHGTo*8j<&9GXWOyH~lD(taL{B@x&i zbSqzx0XgE*&6hQ~|5&GR6)#e+ma*p{a!PeJe%Sc_8bChT6vZ@D@c?x#Yx9=Zt({nE zu;%j0>YCGbJ1>MEtZ!^?g}YgR9H27|rcOy`GKmbyLYQm#_weX1^|T1-;FCxqu4&?2 zfC#|V0}aVTHOTb!D6^w}gj0D@is&@-@cif8<-$f{$hHLRCZgpHPp~U83y>s!Dq;+) z?9%y4kFuPNvjAP@NP#wxX!TqhaX_4_uX`Ktb`WREd19ln;vvCO)?)*q`Esx#evT<( zwH2#J{KTxFRd?{+rms&!xu+BEsBK0QdwgUnx@BytC8Ut?HtN845(BVYFdL1Nf@BSXbdSI`#PZN)1tiMMC znP`JW27?;jCL1&V6h#wmyNVOg_GIDk9#o*h%6wQ)E{K! zSa|P5H&P1ndk)_x56xii&mgna24%WWAsc;)Ji}7>{v*j{$nO)?5)O6|pRL;t(l0W2 z8hFa(T&yCs!CLEZUpuxd$semrvEesFs}sc8z()R4a`!ICqJ;YO8UMyEahN<%@sK*R z*FQjSXj~_uz7ea1Fn9d}*+wiyhaityJfl{X3R0hv*z%mpMqF~c?Rpw2`L#T}K&jjP z*xc((ID#&W$(crMWUI&$|ivIntQFN1vd$H;dZTYraacMdlSlm8F3BJ zMcjKBkv^p~_ii|@QIscdGfdoOr0Yj!zepT7=t*xPXk?m^FR_AC>gA(+e*_rgW+lNK zoH=@A4$G5yT zj1f}p>uHED_CH&%%w+#$Pf;-_WCw9JavrbZY3tGqvzE33?w6B%w2aMV_Dhfu->r&c zsOH0SpDkW{AAX56ib=9H%{?HOF;n@l=~wpi1mSy+?BU$ZtKq{-1VxNb3H2YExjZJr zMwy|M+!$wI3XoH1wYeZ8CeBfDo{IOVAl{UTg_=$xoa~1*KXRQEpO*__jX?Gd?vLoB zYK!-&n^SR-iV_v1h7SwRvBCN5WfFe}DE}G?MWaOAxHc)%Zj`*Ev>qkprqOd!ex<%~ zneI!z3$hFn?E?-Y>!Wbv%ILHi1jUK5?{Wb%+G5WZvjgW+c znWlR>v!5q}-7_MiUx2;^Z=+SD9LSCahspp~=E9G@L;@_i072RasVz!%3t}%jHR(f2 z5;v-8`n^)l#2Mr__h}ivgV)NyKccMLB?|T~rzxg#t$@sZm#&W1c{ozv z=gXzo40yXk7{n9va9ddwuO3|i+$F3o04iYwogwET0=&m&VyW$J9>899$ zBjoyU+{G64Xf03X+2Y|lDnWcMDUyf=@lUNtN3xgWCaw}^sR*ec$3m=A(V;?0(Q#^3 zsQ4Kb^rh^is_0Neps>jHCZC q3O%EPT;#6FJasA@Bs%i1nV%QN$1j*g9Xakov7i?w3RYpPp#CpNFjHs% literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/element.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/__pycache__/element.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6b086e6c332d3f2dcbe19ec3db6a9cbda3b11c42 GIT binary patch literal 65406 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 O5%1p?oDXl>^M3(L!s<2v literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__init__.py new file mode 100644 index 00000000..bd44905e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/__init__.py @@ -0,0 +1,520 @@ +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +from collections import defaultdict +import itertools +import sys +from bs4.element import ( + CharsetMetaAttributeValue, + ContentMetaAttributeValue, + Stylesheet, + Script, + TemplateString, + nonwhitespace_re +) + +__all__ = [ + 'HTMLTreeBuilder', + 'SAXTreeBuilder', + 'TreeBuilder', + 'TreeBuilderRegistry', + ] + +# Some useful features for a TreeBuilder to have. +FAST = 'fast' +PERMISSIVE = 'permissive' +STRICT = 'strict' +XML = 'xml' +HTML = 'html' +HTML_5 = 'html5' + + +class TreeBuilderRegistry(object): + """A way of looking up TreeBuilder subclasses by their name or by desired + features. + """ + + def __init__(self): + self.builders_for_feature = defaultdict(list) + self.builders = [] + + def register(self, treebuilder_class): + """Register a treebuilder based on its advertised features. + + :param treebuilder_class: A subclass of Treebuilder. its .features + attribute should list its features. + """ + for feature in treebuilder_class.features: + self.builders_for_feature[feature].insert(0, treebuilder_class) + self.builders.insert(0, treebuilder_class) + + def lookup(self, *features): + """Look up a TreeBuilder subclass with the desired features. + + :param features: A list of features to look for. If none are + provided, the most recently registered TreeBuilder subclass + will be used. + :return: A TreeBuilder subclass, or None if there's no + registered subclass with all the requested features. + """ + if len(self.builders) == 0: + # There are no builders at all. + return None + + if len(features) == 0: + # They didn't ask for any features. Give them the most + # recently registered builder. + return self.builders[0] + + # Go down the list of features in order, and eliminate any builders + # that don't match every feature. + features = list(features) + features.reverse() + candidates = None + candidate_set = None + while len(features) > 0: + feature = features.pop() + we_have_the_feature = self.builders_for_feature.get(feature, []) + if len(we_have_the_feature) > 0: + if candidates is None: + candidates = we_have_the_feature + candidate_set = set(candidates) + else: + # Eliminate any candidates that don't have this feature. + candidate_set = candidate_set.intersection( + set(we_have_the_feature)) + + # The only valid candidates are the ones in candidate_set. + # Go through the original list of candidates and pick the first one + # that's in candidate_set. + if candidate_set is None: + return None + for candidate in candidates: + if candidate in candidate_set: + return candidate + return None + +# The BeautifulSoup class will take feature lists from developers and use them +# to look up builders in this registry. +builder_registry = TreeBuilderRegistry() + +class TreeBuilder(object): + """Turn a textual document into a Beautiful Soup object tree.""" + + NAME = "[Unknown tree builder]" + ALTERNATE_NAMES = [] + features = [] + + is_xml = False + picklable = False + empty_element_tags = None # A tag will be considered an empty-element + # tag when and only when it has no contents. + + # A value for these tag/attribute combinations is a space- or + # comma-separated list of CDATA, rather than a single CDATA. + DEFAULT_CDATA_LIST_ATTRIBUTES = {} + + # Whitespace should be preserved inside these tags. + DEFAULT_PRESERVE_WHITESPACE_TAGS = set() + + # The textual contents of tags with these names should be + # instantiated with some class other than NavigableString. + DEFAULT_STRING_CONTAINERS = {} + + USE_DEFAULT = object() + + # Most parsers don't keep track of line numbers. + TRACKS_LINE_NUMBERS = False + + def __init__(self, multi_valued_attributes=USE_DEFAULT, + preserve_whitespace_tags=USE_DEFAULT, + store_line_numbers=USE_DEFAULT, + string_containers=USE_DEFAULT, + ): + """Constructor. + + :param multi_valued_attributes: If this is set to None, the + TreeBuilder will not turn any values for attributes like + 'class' into lists. Setting this to a dictionary will + customize this behavior; look at DEFAULT_CDATA_LIST_ATTRIBUTES + for an example. + + Internally, these are called "CDATA list attributes", but that + probably doesn't make sense to an end-user, so the argument name + is `multi_valued_attributes`. + + :param preserve_whitespace_tags: A list of tags to treat + the way

 tags are treated in HTML. Tags in this list
+         are immune from pretty-printing; their contents will always be
+         output as-is.
+
+        :param string_containers: A dictionary mapping tag names to
+        the classes that should be instantiated to contain the textual
+        contents of those tags. The default is to use NavigableString
+        for every tag, no matter what the name. You can override the
+        default by changing DEFAULT_STRING_CONTAINERS.
+
+        :param store_line_numbers: If the parser keeps track of the
+         line numbers and positions of the original markup, that
+         information will, by default, be stored in each corresponding
+         `Tag` object. You can turn this off by passing
+         store_line_numbers=False. If the parser you're using doesn't 
+         keep track of this information, then setting store_line_numbers=True
+         will do nothing.
+        """
+        self.soup = None
+        if multi_valued_attributes is self.USE_DEFAULT:
+            multi_valued_attributes = self.DEFAULT_CDATA_LIST_ATTRIBUTES
+        self.cdata_list_attributes = multi_valued_attributes
+        if preserve_whitespace_tags is self.USE_DEFAULT:
+            preserve_whitespace_tags = self.DEFAULT_PRESERVE_WHITESPACE_TAGS
+        self.preserve_whitespace_tags = preserve_whitespace_tags
+        if store_line_numbers == self.USE_DEFAULT:
+            store_line_numbers = self.TRACKS_LINE_NUMBERS
+        self.store_line_numbers = store_line_numbers 
+        if string_containers == self.USE_DEFAULT:
+            string_containers = self.DEFAULT_STRING_CONTAINERS
+        self.string_containers = string_containers
+        
+    def initialize_soup(self, soup):
+        """The BeautifulSoup object has been initialized and is now
+        being associated with the TreeBuilder.
+
+        :param soup: A BeautifulSoup object.
+        """
+        self.soup = soup
+        
+    def reset(self):
+        """Do any work necessary to reset the underlying parser
+        for a new document.
+
+        By default, this does nothing.
+        """
+        pass
+
+    def can_be_empty_element(self, tag_name):
+        """Might a tag with this name be an empty-element tag?
+
+        The final markup may or may not actually present this tag as
+        self-closing.
+
+        For instance: an HTMLBuilder does not consider a 

tag to be + an empty-element tag (it's not in + HTMLBuilder.empty_element_tags). This means an empty

tag + will be presented as "

", not "

" or "

". + + The default implementation has no opinion about which tags are + empty-element tags, so a tag will be presented as an + empty-element tag if and only if it has no children. + "" will become "", and "bar" will + be left alone. + + :param tag_name: The name of a markup tag. + """ + if self.empty_element_tags is None: + return True + return tag_name in self.empty_element_tags + + def feed(self, markup): + """Run some incoming markup through some parsing process, + populating the `BeautifulSoup` object in self.soup. + + This method is not implemented in TreeBuilder; it must be + implemented in subclasses. + + :return: None. + """ + raise NotImplementedError() + + def prepare_markup(self, markup, user_specified_encoding=None, + document_declared_encoding=None, exclude_encodings=None): + """Run any preliminary steps necessary to make incoming markup + acceptable to the parser. + + :param markup: Some markup -- probably a bytestring. + :param user_specified_encoding: The user asked to try this encoding. + :param document_declared_encoding: The markup itself claims to be + in this encoding. NOTE: This argument is not used by the + calling code and can probably be removed. + :param exclude_encodings: The user asked _not_ to try any of + these encodings. + + :yield: A series of 4-tuples: + (markup, encoding, declared encoding, + has undergone character replacement) + + Each 4-tuple represents a strategy for converting the + document to Unicode and parsing it. Each strategy will be tried + in turn. + + By default, the only strategy is to parse the markup + as-is. See `LXMLTreeBuilderForXML` and + `HTMLParserTreeBuilder` for implementations that take into + account the quirks of particular parsers. + """ + yield markup, None, None, False + + def test_fragment_to_document(self, fragment): + """Wrap an HTML fragment to make it look like a document. + + Different parsers do this differently. For instance, lxml + introduces an empty tag, and html5lib + doesn't. Abstracting this away lets us write simple tests + which run HTML fragments through the parser and compare the + results against other HTML fragments. + + This method should not be used outside of tests. + + :param fragment: A string -- fragment of HTML. + :return: A string -- a full HTML document. + """ + return fragment + + def set_up_substitutions(self, tag): + """Set up any substitutions that will need to be performed on + a `Tag` when it's output as a string. + + By default, this does nothing. See `HTMLTreeBuilder` for a + case where this is used. + + :param tag: A `Tag` + :return: Whether or not a substitution was performed. + """ + return False + + def _replace_cdata_list_attribute_values(self, tag_name, attrs): + """When an attribute value is associated with a tag that can + have multiple values for that attribute, convert the string + value to a list of strings. + + Basically, replaces class="foo bar" with class=["foo", "bar"] + + NOTE: This method modifies its input in place. + + :param tag_name: The name of a tag. + :param attrs: A dictionary containing the tag's attributes. + Any appropriate attribute values will be modified in place. + """ + if not attrs: + return attrs + if self.cdata_list_attributes: + universal = self.cdata_list_attributes.get('*', []) + tag_specific = self.cdata_list_attributes.get( + tag_name.lower(), None) + for attr in list(attrs.keys()): + if attr in universal or (tag_specific and attr in tag_specific): + # We have a "class"-type attribute whose string + # value is a whitespace-separated list of + # values. Split it into a list. + value = attrs[attr] + if isinstance(value, str): + values = nonwhitespace_re.findall(value) + else: + # html5lib sometimes calls setAttributes twice + # for the same tag when rearranging the parse + # tree. On the second call the attribute value + # here is already a list. If this happens, + # leave the value alone rather than trying to + # split it again. + values = value + attrs[attr] = values + return attrs + +class SAXTreeBuilder(TreeBuilder): + """A Beautiful Soup treebuilder that listens for SAX events. + + This is not currently used for anything, but it demonstrates + how a simple TreeBuilder would work. + """ + + def feed(self, markup): + raise NotImplementedError() + + def close(self): + pass + + def startElement(self, name, attrs): + attrs = dict((key[1], value) for key, value in list(attrs.items())) + #print("Start %s, %r" % (name, attrs)) + self.soup.handle_starttag(name, attrs) + + def endElement(self, name): + #print("End %s" % name) + self.soup.handle_endtag(name) + + def startElementNS(self, nsTuple, nodeName, attrs): + # Throw away (ns, nodeName) for now. + self.startElement(nodeName, attrs) + + def endElementNS(self, nsTuple, nodeName): + # Throw away (ns, nodeName) for now. + self.endElement(nodeName) + #handler.endElementNS((ns, node.nodeName), node.nodeName) + + def startPrefixMapping(self, prefix, nodeValue): + # Ignore the prefix for now. + pass + + def endPrefixMapping(self, prefix): + # Ignore the prefix for now. + # handler.endPrefixMapping(prefix) + pass + + def characters(self, content): + self.soup.handle_data(content) + + def startDocument(self): + pass + + def endDocument(self): + pass + + +class HTMLTreeBuilder(TreeBuilder): + """This TreeBuilder knows facts about HTML. + + Such as which tags are empty-element tags. + """ + + empty_element_tags = set([ + # These are from HTML5. + 'area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'menuitem', 'meta', 'param', 'source', 'track', 'wbr', + + # These are from earlier versions of HTML and are removed in HTML5. + 'basefont', 'bgsound', 'command', 'frame', 'image', 'isindex', 'nextid', 'spacer' + ]) + + # The HTML standard defines these as block-level elements. Beautiful + # Soup does not treat these elements differently from other elements, + # but it may do so eventually, and this information is available if + # you need to use it. + block_elements = set(["address", "article", "aside", "blockquote", "canvas", "dd", "div", "dl", "dt", "fieldset", "figcaption", "figure", "footer", "form", "h1", "h2", "h3", "h4", "h5", "h6", "header", "hr", "li", "main", "nav", "noscript", "ol", "output", "p", "pre", "section", "table", "tfoot", "ul", "video"]) + + # The HTML standard defines an unusual content model for these tags. + # We represent this by using a string class other than NavigableString + # inside these tags. + # + # I made this list by going through the HTML spec + # (https://html.spec.whatwg.org/#metadata-content) and looking for + # "metadata content" elements that can contain strings. + # + # TODO: Arguably

as a +# string. +# +# XXX This code can be removed once most Python 3 users are on 3.2.3. +if major == 3 and minor == 2 and not CONSTRUCTOR_TAKES_STRICT: + import re + attrfind_tolerant = re.compile( + r'\s*((?<=[\'"\s])[^\s/>][^\s/=>]*)(\s*=+\s*' + r'(\'[^\']*\'|"[^"]*"|(?![\'"])[^>\s]*))?') + HTMLParserTreeBuilder.attrfind_tolerant = attrfind_tolerant + + locatestarttagend = re.compile(r""" + <[a-zA-Z][-.a-zA-Z0-9:_]* # tag name + (?:\s+ # whitespace before attribute name + (?:[a-zA-Z_][-.:a-zA-Z0-9_]* # attribute name + (?:\s*=\s* # value indicator + (?:'[^']*' # LITA-enclosed value + |\"[^\"]*\" # LIT-enclosed value + |[^'\">\s]+ # bare value + ) + )? + ) + )* + \s* # trailing whitespace +""", re.VERBOSE) + BeautifulSoupHTMLParser.locatestarttagend = locatestarttagend + + from html.parser import tagfind, attrfind + + def parse_starttag(self, i): + self.__starttag_text = None + endpos = self.check_for_whole_start_tag(i) + if endpos < 0: + return endpos + rawdata = self.rawdata + self.__starttag_text = rawdata[i:endpos] + + # Now parse the data between i+1 and j into a tag and attrs + attrs = [] + match = tagfind.match(rawdata, i+1) + assert match, 'unexpected call to parse_starttag()' + k = match.end() + self.lasttag = tag = rawdata[i+1:k].lower() + while k < endpos: + if self.strict: + m = attrfind.match(rawdata, k) + else: + m = attrfind_tolerant.match(rawdata, k) + if not m: + break + attrname, rest, attrvalue = m.group(1, 2, 3) + if not rest: + attrvalue = None + elif attrvalue[:1] == '\'' == attrvalue[-1:] or \ + attrvalue[:1] == '"' == attrvalue[-1:]: + attrvalue = attrvalue[1:-1] + if attrvalue: + attrvalue = self.unescape(attrvalue) + attrs.append((attrname.lower(), attrvalue)) + k = m.end() + + end = rawdata[k:endpos].strip() + if end not in (">", "/>"): + lineno, offset = self.getpos() + if "\n" in self.__starttag_text: + lineno = lineno + self.__starttag_text.count("\n") + offset = len(self.__starttag_text) \ + - self.__starttag_text.rfind("\n") + else: + offset = offset + len(self.__starttag_text) + if self.strict: + self.error("junk characters in start tag: %r" + % (rawdata[k:endpos][:20],)) + self.handle_data(rawdata[i:endpos]) + return endpos + if end.endswith('/>'): + # XHTML-style empty tag: + self.handle_startendtag(tag, attrs) + else: + self.handle_starttag(tag, attrs) + if tag in self.CDATA_CONTENT_ELEMENTS: + self.set_cdata_mode(tag) + return endpos + + def set_cdata_mode(self, elem): + self.cdata_elem = elem.lower() + self.interesting = re.compile(r'' % self.cdata_elem, re.I) + + BeautifulSoupHTMLParser.parse_starttag = parse_starttag + BeautifulSoupHTMLParser.set_cdata_mode = set_cdata_mode + + CONSTRUCTOR_TAKES_STRICT = True diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_lxml.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_lxml.py new file mode 100644 index 00000000..11c9a696 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/builder/_lxml.py @@ -0,0 +1,342 @@ +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +__all__ = [ + 'LXMLTreeBuilderForXML', + 'LXMLTreeBuilder', + ] + +try: + from collections.abc import Callable # Python 3.6 +except ImportError as e: + from collections import Callable + +from io import BytesIO +from io import StringIO +from lxml import etree +from bs4.element import ( + Comment, + Doctype, + NamespacedAttribute, + ProcessingInstruction, + XMLProcessingInstruction, +) +from bs4.builder import ( + FAST, + HTML, + HTMLTreeBuilder, + PERMISSIVE, + ParserRejectedMarkup, + TreeBuilder, + XML) +from bs4.dammit import EncodingDetector + +LXML = 'lxml' + +def _invert(d): + "Invert a dictionary." + return dict((v,k) for k, v in list(d.items())) + +class LXMLTreeBuilderForXML(TreeBuilder): + DEFAULT_PARSER_CLASS = etree.XMLParser + + is_xml = True + processing_instruction_class = XMLProcessingInstruction + + NAME = "lxml-xml" + ALTERNATE_NAMES = ["xml"] + + # Well, it's permissive by XML parser standards. + features = [NAME, LXML, XML, FAST, PERMISSIVE] + + CHUNK_SIZE = 512 + + # This namespace mapping is specified in the XML Namespace + # standard. + DEFAULT_NSMAPS = dict(xml='http://www.w3.org/XML/1998/namespace') + + DEFAULT_NSMAPS_INVERTED = _invert(DEFAULT_NSMAPS) + + # NOTE: If we parsed Element objects and looked at .sourceline, + # we'd be able to see the line numbers from the original document. + # But instead we build an XMLParser or HTMLParser object to serve + # as the target of parse messages, and those messages don't include + # line numbers. + # See: https://bugs.launchpad.net/lxml/+bug/1846906 + + def initialize_soup(self, soup): + """Let the BeautifulSoup object know about the standard namespace + mapping. + + :param soup: A `BeautifulSoup`. + """ + super(LXMLTreeBuilderForXML, self).initialize_soup(soup) + self._register_namespaces(self.DEFAULT_NSMAPS) + + def _register_namespaces(self, mapping): + """Let the BeautifulSoup object know about namespaces encountered + while parsing the document. + + This might be useful later on when creating CSS selectors. + + :param mapping: A dictionary mapping namespace prefixes to URIs. + """ + for key, value in list(mapping.items()): + if key and key not in self.soup._namespaces: + # Let the BeautifulSoup object know about a new namespace. + # If there are multiple namespaces defined with the same + # prefix, the first one in the document takes precedence. + self.soup._namespaces[key] = value + + def default_parser(self, encoding): + """Find the default parser for the given encoding. + + :param encoding: A string. + :return: Either a parser object or a class, which + will be instantiated with default arguments. + """ + if self._default_parser is not None: + return self._default_parser + return etree.XMLParser( + target=self, strip_cdata=False, recover=True, encoding=encoding) + + def parser_for(self, encoding): + """Instantiate an appropriate parser for the given encoding. + + :param encoding: A string. + :return: A parser object such as an `etree.XMLParser`. + """ + # Use the default parser. + parser = self.default_parser(encoding) + + if isinstance(parser, Callable): + # Instantiate the parser with default arguments + parser = parser( + target=self, strip_cdata=False, recover=True, encoding=encoding + ) + return parser + + def __init__(self, parser=None, empty_element_tags=None, **kwargs): + # TODO: Issue a warning if parser is present but not a + # callable, since that means there's no way to create new + # parsers for different encodings. + self._default_parser = parser + if empty_element_tags is not None: + self.empty_element_tags = set(empty_element_tags) + self.soup = None + self.nsmaps = [self.DEFAULT_NSMAPS_INVERTED] + super(LXMLTreeBuilderForXML, self).__init__(**kwargs) + + def _getNsTag(self, tag): + # Split the namespace URL out of a fully-qualified lxml tag + # name. Copied from lxml's src/lxml/sax.py. + if tag[0] == '{': + return tuple(tag[1:].split('}', 1)) + else: + return (None, tag) + + def prepare_markup(self, markup, user_specified_encoding=None, + exclude_encodings=None, + document_declared_encoding=None): + """Run any preliminary steps necessary to make incoming markup + acceptable to the parser. + + lxml really wants to get a bytestring and convert it to + Unicode itself. So instead of using UnicodeDammit to convert + the bytestring to Unicode using different encodings, this + implementation uses EncodingDetector to iterate over the + encodings, and tell lxml to try to parse the document as each + one in turn. + + :param markup: Some markup -- hopefully a bytestring. + :param user_specified_encoding: The user asked to try this encoding. + :param document_declared_encoding: The markup itself claims to be + in this encoding. + :param exclude_encodings: The user asked _not_ to try any of + these encodings. + + :yield: A series of 4-tuples: + (markup, encoding, declared encoding, + has undergone character replacement) + + Each 4-tuple represents a strategy for converting the + document to Unicode and parsing it. Each strategy will be tried + in turn. + """ + is_html = not self.is_xml + if is_html: + self.processing_instruction_class = ProcessingInstruction + else: + self.processing_instruction_class = XMLProcessingInstruction + + if isinstance(markup, str): + # We were given Unicode. Maybe lxml can parse Unicode on + # this system? + yield markup, None, document_declared_encoding, False + + if isinstance(markup, str): + # No, apparently not. Convert the Unicode to UTF-8 and + # tell lxml to parse it as UTF-8. + yield (markup.encode("utf8"), "utf8", + document_declared_encoding, False) + + # This was provided by the end-user; treat it as a known + # definite encoding per the algorithm laid out in the HTML5 + # spec. (See the EncodingDetector class for details.) + known_definite_encodings = [user_specified_encoding] + + # This was found in the document; treat it as a slightly lower-priority + # user encoding. + user_encodings = [document_declared_encoding] + detector = EncodingDetector( + markup, known_definite_encodings=known_definite_encodings, + user_encodings=user_encodings, is_html=is_html, + exclude_encodings=exclude_encodings + ) + for encoding in detector.encodings: + yield (detector.markup, encoding, document_declared_encoding, False) + + def feed(self, markup): + if isinstance(markup, bytes): + markup = BytesIO(markup) + elif isinstance(markup, str): + markup = StringIO(markup) + + # Call feed() at least once, even if the markup is empty, + # or the parser won't be initialized. + data = markup.read(self.CHUNK_SIZE) + try: + self.parser = self.parser_for(self.soup.original_encoding) + self.parser.feed(data) + while len(data) != 0: + # Now call feed() on the rest of the data, chunk by chunk. + data = markup.read(self.CHUNK_SIZE) + if len(data) != 0: + self.parser.feed(data) + self.parser.close() + except (UnicodeDecodeError, LookupError, etree.ParserError) as e: + raise ParserRejectedMarkup(e) + + def close(self): + self.nsmaps = [self.DEFAULT_NSMAPS_INVERTED] + + def start(self, name, attrs, nsmap={}): + # Make sure attrs is a mutable dict--lxml may send an immutable dictproxy. + attrs = dict(attrs) + nsprefix = None + # Invert each namespace map as it comes in. + if len(nsmap) == 0 and len(self.nsmaps) > 1: + # There are no new namespaces for this tag, but + # non-default namespaces are in play, so we need a + # separate tag stack to know when they end. + self.nsmaps.append(None) + elif len(nsmap) > 0: + # A new namespace mapping has come into play. + + # First, Let the BeautifulSoup object know about it. + self._register_namespaces(nsmap) + + # Then, add it to our running list of inverted namespace + # mappings. + self.nsmaps.append(_invert(nsmap)) + + # Also treat the namespace mapping as a set of attributes on the + # tag, so we can recreate it later. + attrs = attrs.copy() + for prefix, namespace in list(nsmap.items()): + attribute = NamespacedAttribute( + "xmlns", prefix, "http://www.w3.org/2000/xmlns/") + attrs[attribute] = namespace + + # Namespaces are in play. Find any attributes that came in + # from lxml with namespaces attached to their names, and + # turn then into NamespacedAttribute objects. + new_attrs = {} + for attr, value in list(attrs.items()): + namespace, attr = self._getNsTag(attr) + if namespace is None: + new_attrs[attr] = value + else: + nsprefix = self._prefix_for_namespace(namespace) + attr = NamespacedAttribute(nsprefix, attr, namespace) + new_attrs[attr] = value + attrs = new_attrs + + namespace, name = self._getNsTag(name) + nsprefix = self._prefix_for_namespace(namespace) + self.soup.handle_starttag(name, namespace, nsprefix, attrs) + + def _prefix_for_namespace(self, namespace): + """Find the currently active prefix for the given namespace.""" + if namespace is None: + return None + for inverted_nsmap in reversed(self.nsmaps): + if inverted_nsmap is not None and namespace in inverted_nsmap: + return inverted_nsmap[namespace] + return None + + def end(self, name): + self.soup.endData() + completed_tag = self.soup.tagStack[-1] + namespace, name = self._getNsTag(name) + nsprefix = None + if namespace is not None: + for inverted_nsmap in reversed(self.nsmaps): + if inverted_nsmap is not None and namespace in inverted_nsmap: + nsprefix = inverted_nsmap[namespace] + break + self.soup.handle_endtag(name, nsprefix) + if len(self.nsmaps) > 1: + # This tag, or one of its parents, introduced a namespace + # mapping, so pop it off the stack. + self.nsmaps.pop() + + def pi(self, target, data): + self.soup.endData() + self.soup.handle_data(target + ' ' + data) + self.soup.endData(self.processing_instruction_class) + + def data(self, content): + self.soup.handle_data(content) + + def doctype(self, name, pubid, system): + self.soup.endData() + doctype = Doctype.for_name_and_ids(name, pubid, system) + self.soup.object_was_parsed(doctype) + + def comment(self, content): + "Handle comments as Comment objects." + self.soup.endData() + self.soup.handle_data(content) + self.soup.endData(Comment) + + def test_fragment_to_document(self, fragment): + """See `TreeBuilder`.""" + return '\n%s' % fragment + + +class LXMLTreeBuilder(HTMLTreeBuilder, LXMLTreeBuilderForXML): + + NAME = LXML + ALTERNATE_NAMES = ["lxml-html"] + + features = ALTERNATE_NAMES + [NAME, HTML, FAST, PERMISSIVE] + is_xml = False + processing_instruction_class = ProcessingInstruction + + def default_parser(self, encoding): + return etree.HTMLParser + + def feed(self, markup): + encoding = self.soup.original_encoding + try: + self.parser = self.parser_for(encoding) + self.parser.feed(markup) + self.parser.close() + except (UnicodeDecodeError, LookupError, etree.ParserError) as e: + raise ParserRejectedMarkup(e) + + + def test_fragment_to_document(self, fragment): + """See `TreeBuilder`.""" + return '%s' % fragment diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/dammit.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/dammit.py new file mode 100644 index 00000000..e017408b --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/dammit.py @@ -0,0 +1,3338 @@ +# -*- coding: utf-8 -*- +"""Beautiful Soup bonus library: Unicode, Dammit + +This library converts a bytestream to Unicode through any means +necessary. It is heavily based on code from Mark Pilgrim's Universal +Feed Parser. It works best on XML and HTML, but it does not rewrite the +XML or HTML to reflect a new encoding; that's the tree builder's job. +""" +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +from html.entities import codepoint2name +from collections import defaultdict +import codecs +import re +import logging +import string + +# Import a library to autodetect character encodings. +chardet_type = None +try: + # First try the fast C implementation. + # PyPI package: cchardet + import cchardet + def chardet_dammit(s): + if isinstance(s, str): + return None + return cchardet.detect(s)['encoding'] +except ImportError: + try: + # Fall back to the pure Python implementation + # Debian package: python-chardet + # PyPI package: chardet + import chardet + def chardet_dammit(s): + if isinstance(s, str): + return None + return chardet.detect(s)['encoding'] + #import chardet.constants + #chardet.constants._debug = 1 + except ImportError: + # No chardet available. + def chardet_dammit(s): + return None + +# Available from http://cjkpython.i18n.org/. +# +# TODO: This doesn't work anymore and the closest thing, iconv_codecs, +# is GPL-licensed. Check whether this is still necessary. +try: + import iconv_codec +except ImportError: + pass + +# Build bytestring and Unicode versions of regular expressions for finding +# a declared encoding inside an XML or HTML document. +xml_encoding = '^\\s*<\\?.*encoding=[\'"](.*?)[\'"].*\\?>' +html_meta = '<\\s*meta[^>]+charset\\s*=\\s*["\']?([^>]*?)[ /;\'">]' +encoding_res = dict() +encoding_res[bytes] = { + 'html' : re.compile(html_meta.encode("ascii"), re.I), + 'xml' : re.compile(xml_encoding.encode("ascii"), re.I), +} +encoding_res[str] = { + 'html' : re.compile(html_meta, re.I), + 'xml' : re.compile(xml_encoding, re.I) +} + +try: + from html.entities import html5 +except ImportError: + # This is a copy of html.entities.html5 from Python 3.9. There's + # no equivalent table in Python 2, so we'll just provide a copy + # here. + html5 = { + 'Aacute': '\xc1', + 'aacute': '\xe1', + 'Aacute;': '\xc1', + 'aacute;': '\xe1', + 'Abreve;': '\u0102', + 'abreve;': '\u0103', + 'ac;': '\u223e', + 'acd;': '\u223f', + 'acE;': '\u223e\u0333', + 'Acirc': '\xc2', + 'acirc': '\xe2', + 'Acirc;': '\xc2', + 'acirc;': '\xe2', + 'acute': '\xb4', + 'acute;': '\xb4', + 'Acy;': '\u0410', + 'acy;': '\u0430', + 'AElig': '\xc6', + 'aelig': '\xe6', + 'AElig;': '\xc6', + 'aelig;': '\xe6', + 'af;': '\u2061', + 'Afr;': '\U0001d504', + 'afr;': '\U0001d51e', + 'Agrave': '\xc0', + 'agrave': '\xe0', + 'Agrave;': '\xc0', + 'agrave;': '\xe0', + 'alefsym;': '\u2135', + 'aleph;': '\u2135', + 'Alpha;': '\u0391', + 'alpha;': '\u03b1', + 'Amacr;': '\u0100', + 'amacr;': '\u0101', + 'amalg;': '\u2a3f', + 'AMP': '&', + 'amp': '&', + 'AMP;': '&', + 'amp;': '&', + 'And;': '\u2a53', + '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;': '\u0104', + 'aogon;': '\u0105', + 'Aopf;': '\U0001d538', + 'aopf;': '\U0001d552', + 'ap;': '\u2248', + 'apacir;': '\u2a6f', + 'apE;': '\u2a70', + 'ape;': '\u224a', + 'apid;': '\u224b', + 'apos;': "'", + 'ApplyFunction;': '\u2061', + 'approx;': '\u2248', + 'approxeq;': '\u224a', + 'Aring': '\xc5', + 'aring': '\xe5', + 'Aring;': '\xc5', + 'aring;': '\xe5', + 'Ascr;': '\U0001d49c', + 'ascr;': '\U0001d4b6', + 'Assign;': '\u2254', + 'ast;': '*', + 'asymp;': '\u2248', + 'asympeq;': '\u224d', + 'Atilde': '\xc3', + 'atilde': '\xe3', + 'Atilde;': '\xc3', + 'atilde;': '\xe3', + 'Auml': '\xc4', + 'auml': '\xe4', + 'Auml;': '\xc4', + 'auml;': '\xe4', + 'awconint;': '\u2233', + 'awint;': '\u2a11', + 'backcong;': '\u224c', + 'backepsilon;': '\u03f6', + 'backprime;': '\u2035', + 'backsim;': '\u223d', + 'backsimeq;': '\u22cd', + 'Backslash;': '\u2216', + 'Barv;': '\u2ae7', + 'barvee;': '\u22bd', + 'Barwed;': '\u2306', + 'barwed;': '\u2305', + 'barwedge;': '\u2305', + 'bbrk;': '\u23b5', + 'bbrktbrk;': '\u23b6', + 'bcong;': '\u224c', + 'Bcy;': '\u0411', + 'bcy;': '\u0431', + 'bdquo;': '\u201e', + 'becaus;': '\u2235', + 'Because;': '\u2235', + 'because;': '\u2235', + 'bemptyv;': '\u29b0', + 'bepsi;': '\u03f6', + 'bernou;': '\u212c', + 'Bernoullis;': '\u212c', + 'Beta;': '\u0392', + 'beta;': '\u03b2', + 'beth;': '\u2136', + 'between;': '\u226c', + 'Bfr;': '\U0001d505', + '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;': '\u2aed', + 'bnot;': '\u2310', + 'Bopf;': '\U0001d539', + 'bopf;': '\U0001d553', + 'bot;': '\u22a5', + 'bottom;': '\u22a5', + 'bowtie;': '\u22c8', + 'boxbox;': '\u29c9', + 'boxDL;': '\u2557', + 'boxDl;': '\u2556', + 'boxdL;': '\u2555', + 'boxdl;': '\u2510', + 'boxDR;': '\u2554', + 'boxDr;': '\u2553', + 'boxdR;': '\u2552', + 'boxdr;': '\u250c', + 'boxH;': '\u2550', + 'boxh;': '\u2500', + 'boxHD;': '\u2566', + 'boxHd;': '\u2564', + 'boxhD;': '\u2565', + 'boxhd;': '\u252c', + 'boxHU;': '\u2569', + 'boxHu;': '\u2567', + 'boxhU;': '\u2568', + 'boxhu;': '\u2534', + 'boxminus;': '\u229f', + 'boxplus;': '\u229e', + 'boxtimes;': '\u22a0', + 'boxUL;': '\u255d', + 'boxUl;': '\u255c', + 'boxuL;': '\u255b', + 'boxul;': '\u2518', + 'boxUR;': '\u255a', + 'boxUr;': '\u2559', + 'boxuR;': '\u2558', + 'boxur;': '\u2514', + 'boxV;': '\u2551', + 'boxv;': '\u2502', + 'boxVH;': '\u256c', + 'boxVh;': '\u256b', + 'boxvH;': '\u256a', + 'boxvh;': '\u253c', + 'boxVL;': '\u2563', + 'boxVl;': '\u2562', + 'boxvL;': '\u2561', + 'boxvl;': '\u2524', + 'boxVR;': '\u2560', + 'boxVr;': '\u255f', + 'boxvR;': '\u255e', + 'boxvr;': '\u251c', + 'bprime;': '\u2035', + 'Breve;': '\u02d8', + 'breve;': '\u02d8', + 'brvbar': '\xa6', + 'brvbar;': '\xa6', + 'Bscr;': '\u212c', + 'bscr;': '\U0001d4b7', + 'bsemi;': '\u204f', + 'bsim;': '\u223d', + 'bsime;': '\u22cd', + 'bsol;': '\\', + 'bsolb;': '\u29c5', + 'bsolhsub;': '\u27c8', + 'bull;': '\u2022', + 'bullet;': '\u2022', + 'bump;': '\u224e', + 'bumpE;': '\u2aae', + 'bumpe;': '\u224f', + 'Bumpeq;': '\u224e', + 'bumpeq;': '\u224f', + 'Cacute;': '\u0106', + 'cacute;': '\u0107', + 'Cap;': '\u22d2', + 'cap;': '\u2229', + 'capand;': '\u2a44', + 'capbrcup;': '\u2a49', + 'capcap;': '\u2a4b', + 'capcup;': '\u2a47', + 'capdot;': '\u2a40', + 'CapitalDifferentialD;': '\u2145', + 'caps;': '\u2229\ufe00', + 'caret;': '\u2041', + 'caron;': '\u02c7', + 'Cayleys;': '\u212d', + 'ccaps;': '\u2a4d', + 'Ccaron;': '\u010c', + 'ccaron;': '\u010d', + 'Ccedil': '\xc7', + 'ccedil': '\xe7', + 'Ccedil;': '\xc7', + 'ccedil;': '\xe7', + 'Ccirc;': '\u0108', + 'ccirc;': '\u0109', + 'Cconint;': '\u2230', + 'ccups;': '\u2a4c', + 'ccupssm;': '\u2a50', + 'Cdot;': '\u010a', + 'cdot;': '\u010b', + 'cedil': '\xb8', + 'cedil;': '\xb8', + 'Cedilla;': '\xb8', + 'cemptyv;': '\u29b2', + 'cent': '\xa2', + 'cent;': '\xa2', + 'CenterDot;': '\xb7', + 'centerdot;': '\xb7', + 'Cfr;': '\u212d', + 'cfr;': '\U0001d520', + 'CHcy;': '\u0427', + 'chcy;': '\u0447', + 'check;': '\u2713', + 'checkmark;': '\u2713', + 'Chi;': '\u03a7', + 'chi;': '\u03c7', + 'cir;': '\u25cb', + 'circ;': '\u02c6', + 'circeq;': '\u2257', + 'circlearrowleft;': '\u21ba', + 'circlearrowright;': '\u21bb', + 'circledast;': '\u229b', + 'circledcirc;': '\u229a', + 'circleddash;': '\u229d', + 'CircleDot;': '\u2299', + 'circledR;': '\xae', + 'circledS;': '\u24c8', + 'CircleMinus;': '\u2296', + 'CirclePlus;': '\u2295', + 'CircleTimes;': '\u2297', + 'cirE;': '\u29c3', + 'cire;': '\u2257', + 'cirfnint;': '\u2a10', + 'cirmid;': '\u2aef', + 'cirscir;': '\u29c2', + 'ClockwiseContourIntegral;': '\u2232', + 'CloseCurlyDoubleQuote;': '\u201d', + 'CloseCurlyQuote;': '\u2019', + 'clubs;': '\u2663', + 'clubsuit;': '\u2663', + 'Colon;': '\u2237', + 'colon;': ':', + 'Colone;': '\u2a74', + 'colone;': '\u2254', + 'coloneq;': '\u2254', + 'comma;': ',', + 'commat;': '@', + 'comp;': '\u2201', + 'compfn;': '\u2218', + 'complement;': '\u2201', + 'complexes;': '\u2102', + 'cong;': '\u2245', + 'congdot;': '\u2a6d', + 'Congruent;': '\u2261', + 'Conint;': '\u222f', + 'conint;': '\u222e', + 'ContourIntegral;': '\u222e', + 'Copf;': '\u2102', + 'copf;': '\U0001d554', + 'coprod;': '\u2210', + 'Coproduct;': '\u2210', + 'COPY': '\xa9', + 'copy': '\xa9', + 'COPY;': '\xa9', + 'copy;': '\xa9', + 'copysr;': '\u2117', + 'CounterClockwiseContourIntegral;': '\u2233', + 'crarr;': '\u21b5', + 'Cross;': '\u2a2f', + 'cross;': '\u2717', + 'Cscr;': '\U0001d49e', + '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;': '\u22d3', + 'cup;': '\u222a', + 'cupbrcap;': '\u2a48', + 'CupCap;': '\u224d', + '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', + 'Dagger;': '\u2021', + 'dagger;': '\u2020', + 'daleth;': '\u2138', + 'Darr;': '\u21a1', + 'dArr;': '\u21d3', + 'darr;': '\u2193', + 'dash;': '\u2010', + 'Dashv;': '\u2ae4', + 'dashv;': '\u22a3', + 'dbkarow;': '\u290f', + 'dblac;': '\u02dd', + 'Dcaron;': '\u010e', + 'dcaron;': '\u010f', + 'Dcy;': '\u0414', + 'dcy;': '\u0434', + 'DD;': '\u2145', + 'dd;': '\u2146', + 'ddagger;': '\u2021', + 'ddarr;': '\u21ca', + 'DDotrahd;': '\u2911', + 'ddotseq;': '\u2a77', + 'deg': '\xb0', + 'deg;': '\xb0', + 'Del;': '\u2207', + 'Delta;': '\u0394', + 'delta;': '\u03b4', + 'demptyv;': '\u29b1', + 'dfisht;': '\u297f', + 'Dfr;': '\U0001d507', + 'dfr;': '\U0001d521', + 'dHar;': '\u2965', + 'dharl;': '\u21c3', + 'dharr;': '\u21c2', + 'DiacriticalAcute;': '\xb4', + 'DiacriticalDot;': '\u02d9', + 'DiacriticalDoubleAcute;': '\u02dd', + 'DiacriticalGrave;': '`', + 'DiacriticalTilde;': '\u02dc', + 'diam;': '\u22c4', + 'Diamond;': '\u22c4', + 'diamond;': '\u22c4', + 'diamondsuit;': '\u2666', + 'diams;': '\u2666', + 'die;': '\xa8', + 'DifferentialD;': '\u2146', + 'digamma;': '\u03dd', + 'disin;': '\u22f2', + 'div;': '\xf7', + 'divide': '\xf7', + 'divide;': '\xf7', + 'divideontimes;': '\u22c7', + 'divonx;': '\u22c7', + 'DJcy;': '\u0402', + 'djcy;': '\u0452', + 'dlcorn;': '\u231e', + 'dlcrop;': '\u230d', + 'dollar;': '$', + 'Dopf;': '\U0001d53b', + 'dopf;': '\U0001d555', + 'Dot;': '\xa8', + 'dot;': '\u02d9', + 'DotDot;': '\u20dc', + 'doteq;': '\u2250', + 'doteqdot;': '\u2251', + 'DotEqual;': '\u2250', + 'dotminus;': '\u2238', + 'dotplus;': '\u2214', + 'dotsquare;': '\u22a1', + 'doublebarwedge;': '\u2306', + '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', + 'Downarrow;': '\u21d3', + 'downarrow;': '\u2193', + 'DownArrowBar;': '\u2913', + 'DownArrowUpArrow;': '\u21f5', + 'DownBreve;': '\u0311', + 'downdownarrows;': '\u21ca', + 'downharpoonleft;': '\u21c3', + 'downharpoonright;': '\u21c2', + 'DownLeftRightVector;': '\u2950', + 'DownLeftTeeVector;': '\u295e', + 'DownLeftVector;': '\u21bd', + 'DownLeftVectorBar;': '\u2956', + 'DownRightTeeVector;': '\u295f', + 'DownRightVector;': '\u21c1', + 'DownRightVectorBar;': '\u2957', + 'DownTee;': '\u22a4', + 'DownTeeArrow;': '\u21a7', + 'drbkarow;': '\u2910', + 'drcorn;': '\u231f', + 'drcrop;': '\u230c', + 'Dscr;': '\U0001d49f', + 'dscr;': '\U0001d4b9', + 'DScy;': '\u0405', + 'dscy;': '\u0455', + 'dsol;': '\u29f6', + 'Dstrok;': '\u0110', + 'dstrok;': '\u0111', + 'dtdot;': '\u22f1', + 'dtri;': '\u25bf', + 'dtrif;': '\u25be', + 'duarr;': '\u21f5', + 'duhar;': '\u296f', + 'dwangle;': '\u29a6', + 'DZcy;': '\u040f', + 'dzcy;': '\u045f', + 'dzigrarr;': '\u27ff', + 'Eacute': '\xc9', + 'eacute': '\xe9', + 'Eacute;': '\xc9', + 'eacute;': '\xe9', + 'easter;': '\u2a6e', + 'Ecaron;': '\u011a', + 'ecaron;': '\u011b', + 'ecir;': '\u2256', + 'Ecirc': '\xca', + 'ecirc': '\xea', + 'Ecirc;': '\xca', + 'ecirc;': '\xea', + 'ecolon;': '\u2255', + 'Ecy;': '\u042d', + 'ecy;': '\u044d', + 'eDDot;': '\u2a77', + 'Edot;': '\u0116', + 'eDot;': '\u2251', + 'edot;': '\u0117', + 'ee;': '\u2147', + 'efDot;': '\u2252', + 'Efr;': '\U0001d508', + 'efr;': '\U0001d522', + 'eg;': '\u2a9a', + 'Egrave': '\xc8', + 'egrave': '\xe8', + 'Egrave;': '\xc8', + 'egrave;': '\xe8', + 'egs;': '\u2a96', + 'egsdot;': '\u2a98', + 'el;': '\u2a99', + 'Element;': '\u2208', + 'elinters;': '\u23e7', + 'ell;': '\u2113', + 'els;': '\u2a95', + 'elsdot;': '\u2a97', + 'Emacr;': '\u0112', + 'emacr;': '\u0113', + 'empty;': '\u2205', + 'emptyset;': '\u2205', + 'EmptySmallSquare;': '\u25fb', + 'emptyv;': '\u2205', + 'EmptyVerySmallSquare;': '\u25ab', + 'emsp13;': '\u2004', + 'emsp14;': '\u2005', + 'emsp;': '\u2003', + 'ENG;': '\u014a', + 'eng;': '\u014b', + 'ensp;': '\u2002', + 'Eogon;': '\u0118', + 'eogon;': '\u0119', + 'Eopf;': '\U0001d53c', + 'eopf;': '\U0001d556', + 'epar;': '\u22d5', + 'eparsl;': '\u29e3', + 'eplus;': '\u2a71', + 'epsi;': '\u03b5', + 'Epsilon;': '\u0395', + 'epsilon;': '\u03b5', + 'epsiv;': '\u03f5', + 'eqcirc;': '\u2256', + 'eqcolon;': '\u2255', + 'eqsim;': '\u2242', + 'eqslantgtr;': '\u2a96', + 'eqslantless;': '\u2a95', + 'Equal;': '\u2a75', + 'equals;': '=', + 'EqualTilde;': '\u2242', + 'equest;': '\u225f', + 'Equilibrium;': '\u21cc', + 'equiv;': '\u2261', + 'equivDD;': '\u2a78', + 'eqvparsl;': '\u29e5', + 'erarr;': '\u2971', + 'erDot;': '\u2253', + 'Escr;': '\u2130', + 'escr;': '\u212f', + 'esdot;': '\u2250', + 'Esim;': '\u2a73', + 'esim;': '\u2242', + 'Eta;': '\u0397', + 'eta;': '\u03b7', + 'ETH': '\xd0', + 'eth': '\xf0', + 'ETH;': '\xd0', + 'eth;': '\xf0', + 'Euml': '\xcb', + 'euml': '\xeb', + 'Euml;': '\xcb', + 'euml;': '\xeb', + 'euro;': '\u20ac', + 'excl;': '!', + 'exist;': '\u2203', + 'Exists;': '\u2203', + 'expectation;': '\u2130', + 'ExponentialE;': '\u2147', + 'exponentiale;': '\u2147', + 'fallingdotseq;': '\u2252', + 'Fcy;': '\u0424', + 'fcy;': '\u0444', + 'female;': '\u2640', + 'ffilig;': '\ufb03', + 'fflig;': '\ufb00', + 'ffllig;': '\ufb04', + 'Ffr;': '\U0001d509', + 'ffr;': '\U0001d523', + 'filig;': '\ufb01', + 'FilledSmallSquare;': '\u25fc', + 'FilledVerySmallSquare;': '\u25aa', + 'fjlig;': 'fj', + 'flat;': '\u266d', + 'fllig;': '\ufb02', + 'fltns;': '\u25b1', + 'fnof;': '\u0192', + 'Fopf;': '\U0001d53d', + 'fopf;': '\U0001d557', + 'ForAll;': '\u2200', + 'forall;': '\u2200', + 'fork;': '\u22d4', + 'forkv;': '\u2ad9', + 'Fouriertrf;': '\u2131', + '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;': '\u2131', + 'fscr;': '\U0001d4bb', + 'gacute;': '\u01f5', + 'Gamma;': '\u0393', + 'gamma;': '\u03b3', + 'Gammad;': '\u03dc', + 'gammad;': '\u03dd', + 'gap;': '\u2a86', + 'Gbreve;': '\u011e', + 'gbreve;': '\u011f', + 'Gcedil;': '\u0122', + 'Gcirc;': '\u011c', + 'gcirc;': '\u011d', + 'Gcy;': '\u0413', + 'gcy;': '\u0433', + 'Gdot;': '\u0120', + 'gdot;': '\u0121', + 'gE;': '\u2267', + 'ge;': '\u2265', + 'gEl;': '\u2a8c', + 'gel;': '\u22db', + 'geq;': '\u2265', + 'geqq;': '\u2267', + 'geqslant;': '\u2a7e', + 'ges;': '\u2a7e', + 'gescc;': '\u2aa9', + 'gesdot;': '\u2a80', + 'gesdoto;': '\u2a82', + 'gesdotol;': '\u2a84', + 'gesl;': '\u22db\ufe00', + 'gesles;': '\u2a94', + 'Gfr;': '\U0001d50a', + 'gfr;': '\U0001d524', + 'Gg;': '\u22d9', + 'gg;': '\u226b', + 'ggg;': '\u22d9', + 'gimel;': '\u2137', + 'GJcy;': '\u0403', + 'gjcy;': '\u0453', + 'gl;': '\u2277', + 'gla;': '\u2aa5', + 'glE;': '\u2a92', + 'glj;': '\u2aa4', + 'gnap;': '\u2a8a', + 'gnapprox;': '\u2a8a', + 'gnE;': '\u2269', + 'gne;': '\u2a88', + 'gneq;': '\u2a88', + 'gneqq;': '\u2269', + 'gnsim;': '\u22e7', + 'Gopf;': '\U0001d53e', + 'gopf;': '\U0001d558', + 'grave;': '`', + 'GreaterEqual;': '\u2265', + 'GreaterEqualLess;': '\u22db', + 'GreaterFullEqual;': '\u2267', + 'GreaterGreater;': '\u2aa2', + 'GreaterLess;': '\u2277', + 'GreaterSlantEqual;': '\u2a7e', + 'GreaterTilde;': '\u2273', + 'Gscr;': '\U0001d4a2', + 'gscr;': '\u210a', + 'gsim;': '\u2273', + 'gsime;': '\u2a8e', + 'gsiml;': '\u2a90', + 'GT': '>', + 'gt': '>', + 'GT;': '>', + 'Gt;': '\u226b', + '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', + 'Hacek;': '\u02c7', + 'hairsp;': '\u200a', + 'half;': '\xbd', + 'hamilt;': '\u210b', + 'HARDcy;': '\u042a', + 'hardcy;': '\u044a', + 'hArr;': '\u21d4', + 'harr;': '\u2194', + 'harrcir;': '\u2948', + 'harrw;': '\u21ad', + 'Hat;': '^', + 'hbar;': '\u210f', + 'Hcirc;': '\u0124', + 'hcirc;': '\u0125', + 'hearts;': '\u2665', + 'heartsuit;': '\u2665', + 'hellip;': '\u2026', + 'hercon;': '\u22b9', + 'Hfr;': '\u210c', + 'hfr;': '\U0001d525', + 'HilbertSpace;': '\u210b', + 'hksearow;': '\u2925', + 'hkswarow;': '\u2926', + 'hoarr;': '\u21ff', + 'homtht;': '\u223b', + 'hookleftarrow;': '\u21a9', + 'hookrightarrow;': '\u21aa', + 'Hopf;': '\u210d', + 'hopf;': '\U0001d559', + 'horbar;': '\u2015', + 'HorizontalLine;': '\u2500', + 'Hscr;': '\u210b', + 'hscr;': '\U0001d4bd', + 'hslash;': '\u210f', + 'Hstrok;': '\u0126', + 'hstrok;': '\u0127', + 'HumpDownHump;': '\u224e', + 'HumpEqual;': '\u224f', + 'hybull;': '\u2043', + 'hyphen;': '\u2010', + 'Iacute': '\xcd', + 'iacute': '\xed', + 'Iacute;': '\xcd', + 'iacute;': '\xed', + 'ic;': '\u2063', + 'Icirc': '\xce', + 'icirc': '\xee', + 'Icirc;': '\xce', + 'icirc;': '\xee', + 'Icy;': '\u0418', + 'icy;': '\u0438', + 'Idot;': '\u0130', + 'IEcy;': '\u0415', + 'iecy;': '\u0435', + 'iexcl': '\xa1', + 'iexcl;': '\xa1', + 'iff;': '\u21d4', + 'Ifr;': '\u2111', + 'ifr;': '\U0001d526', + 'Igrave': '\xcc', + 'igrave': '\xec', + 'Igrave;': '\xcc', + 'igrave;': '\xec', + 'ii;': '\u2148', + 'iiiint;': '\u2a0c', + 'iiint;': '\u222d', + 'iinfin;': '\u29dc', + 'iiota;': '\u2129', + 'IJlig;': '\u0132', + 'ijlig;': '\u0133', + 'Im;': '\u2111', + 'Imacr;': '\u012a', + 'imacr;': '\u012b', + 'image;': '\u2111', + 'ImaginaryI;': '\u2148', + 'imagline;': '\u2110', + 'imagpart;': '\u2111', + 'imath;': '\u0131', + 'imof;': '\u22b7', + 'imped;': '\u01b5', + 'Implies;': '\u21d2', + 'in;': '\u2208', + 'incare;': '\u2105', + 'infin;': '\u221e', + 'infintie;': '\u29dd', + 'inodot;': '\u0131', + 'Int;': '\u222c', + 'int;': '\u222b', + 'intcal;': '\u22ba', + 'integers;': '\u2124', + 'Integral;': '\u222b', + 'intercal;': '\u22ba', + 'Intersection;': '\u22c2', + 'intlarhk;': '\u2a17', + 'intprod;': '\u2a3c', + 'InvisibleComma;': '\u2063', + 'InvisibleTimes;': '\u2062', + 'IOcy;': '\u0401', + 'iocy;': '\u0451', + 'Iogon;': '\u012e', + 'iogon;': '\u012f', + 'Iopf;': '\U0001d540', + 'iopf;': '\U0001d55a', + 'Iota;': '\u0399', + 'iota;': '\u03b9', + 'iprod;': '\u2a3c', + 'iquest': '\xbf', + 'iquest;': '\xbf', + 'Iscr;': '\u2110', + 'iscr;': '\U0001d4be', + 'isin;': '\u2208', + 'isindot;': '\u22f5', + 'isinE;': '\u22f9', + 'isins;': '\u22f4', + 'isinsv;': '\u22f3', + 'isinv;': '\u2208', + 'it;': '\u2062', + 'Itilde;': '\u0128', + 'itilde;': '\u0129', + 'Iukcy;': '\u0406', + 'iukcy;': '\u0456', + 'Iuml': '\xcf', + 'iuml': '\xef', + 'Iuml;': '\xcf', + 'iuml;': '\xef', + 'Jcirc;': '\u0134', + 'jcirc;': '\u0135', + 'Jcy;': '\u0419', + 'jcy;': '\u0439', + 'Jfr;': '\U0001d50d', + 'jfr;': '\U0001d527', + 'jmath;': '\u0237', + 'Jopf;': '\U0001d541', + 'jopf;': '\U0001d55b', + 'Jscr;': '\U0001d4a5', + 'jscr;': '\U0001d4bf', + 'Jsercy;': '\u0408', + 'jsercy;': '\u0458', + 'Jukcy;': '\u0404', + 'jukcy;': '\u0454', + 'Kappa;': '\u039a', + 'kappa;': '\u03ba', + 'kappav;': '\u03f0', + 'Kcedil;': '\u0136', + 'kcedil;': '\u0137', + 'Kcy;': '\u041a', + 'kcy;': '\u043a', + 'Kfr;': '\U0001d50e', + 'kfr;': '\U0001d528', + 'kgreen;': '\u0138', + 'KHcy;': '\u0425', + 'khcy;': '\u0445', + 'KJcy;': '\u040c', + 'kjcy;': '\u045c', + 'Kopf;': '\U0001d542', + 'kopf;': '\U0001d55c', + 'Kscr;': '\U0001d4a6', + 'kscr;': '\U0001d4c0', + 'lAarr;': '\u21da', + 'Lacute;': '\u0139', + 'lacute;': '\u013a', + 'laemptyv;': '\u29b4', + 'lagran;': '\u2112', + 'Lambda;': '\u039b', + 'lambda;': '\u03bb', + 'Lang;': '\u27ea', + 'lang;': '\u27e8', + 'langd;': '\u2991', + 'langle;': '\u27e8', + 'lap;': '\u2a85', + 'Laplacetrf;': '\u2112', + 'laquo': '\xab', + 'laquo;': '\xab', + 'Larr;': '\u219e', + 'lArr;': '\u21d0', + 'larr;': '\u2190', + 'larrb;': '\u21e4', + 'larrbfs;': '\u291f', + 'larrfs;': '\u291d', + 'larrhk;': '\u21a9', + 'larrlp;': '\u21ab', + 'larrpl;': '\u2939', + 'larrsim;': '\u2973', + 'larrtl;': '\u21a2', + 'lat;': '\u2aab', + 'lAtail;': '\u291b', + 'latail;': '\u2919', + 'late;': '\u2aad', + 'lates;': '\u2aad\ufe00', + 'lBarr;': '\u290e', + 'lbarr;': '\u290c', + 'lbbrk;': '\u2772', + 'lbrace;': '{', + 'lbrack;': '[', + 'lbrke;': '\u298b', + 'lbrksld;': '\u298f', + 'lbrkslu;': '\u298d', + 'Lcaron;': '\u013d', + 'lcaron;': '\u013e', + 'Lcedil;': '\u013b', + 'lcedil;': '\u013c', + 'lceil;': '\u2308', + 'lcub;': '{', + 'Lcy;': '\u041b', + 'lcy;': '\u043b', + 'ldca;': '\u2936', + 'ldquo;': '\u201c', + 'ldquor;': '\u201e', + 'ldrdhar;': '\u2967', + 'ldrushar;': '\u294b', + 'ldsh;': '\u21b2', + 'lE;': '\u2266', + 'le;': '\u2264', + 'LeftAngleBracket;': '\u27e8', + 'LeftArrow;': '\u2190', + 'Leftarrow;': '\u21d0', + 'leftarrow;': '\u2190', + 'LeftArrowBar;': '\u21e4', + 'LeftArrowRightArrow;': '\u21c6', + 'leftarrowtail;': '\u21a2', + 'LeftCeiling;': '\u2308', + 'LeftDoubleBracket;': '\u27e6', + 'LeftDownTeeVector;': '\u2961', + 'LeftDownVector;': '\u21c3', + 'LeftDownVectorBar;': '\u2959', + 'LeftFloor;': '\u230a', + 'leftharpoondown;': '\u21bd', + 'leftharpoonup;': '\u21bc', + 'leftleftarrows;': '\u21c7', + 'LeftRightArrow;': '\u2194', + 'Leftrightarrow;': '\u21d4', + 'leftrightarrow;': '\u2194', + 'leftrightarrows;': '\u21c6', + 'leftrightharpoons;': '\u21cb', + 'leftrightsquigarrow;': '\u21ad', + 'LeftRightVector;': '\u294e', + 'LeftTee;': '\u22a3', + 'LeftTeeArrow;': '\u21a4', + 'LeftTeeVector;': '\u295a', + 'leftthreetimes;': '\u22cb', + 'LeftTriangle;': '\u22b2', + 'LeftTriangleBar;': '\u29cf', + 'LeftTriangleEqual;': '\u22b4', + 'LeftUpDownVector;': '\u2951', + 'LeftUpTeeVector;': '\u2960', + 'LeftUpVector;': '\u21bf', + 'LeftUpVectorBar;': '\u2958', + 'LeftVector;': '\u21bc', + 'LeftVectorBar;': '\u2952', + 'lEg;': '\u2a8b', + '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', + 'LessEqualGreater;': '\u22da', + 'LessFullEqual;': '\u2266', + 'LessGreater;': '\u2276', + 'lessgtr;': '\u2276', + 'LessLess;': '\u2aa1', + 'lesssim;': '\u2272', + 'LessSlantEqual;': '\u2a7d', + 'LessTilde;': '\u2272', + 'lfisht;': '\u297c', + 'lfloor;': '\u230a', + 'Lfr;': '\U0001d50f', + 'lfr;': '\U0001d529', + 'lg;': '\u2276', + 'lgE;': '\u2a91', + 'lHar;': '\u2962', + 'lhard;': '\u21bd', + 'lharu;': '\u21bc', + 'lharul;': '\u296a', + 'lhblk;': '\u2584', + 'LJcy;': '\u0409', + 'ljcy;': '\u0459', + 'Ll;': '\u22d8', + 'll;': '\u226a', + 'llarr;': '\u21c7', + 'llcorner;': '\u231e', + 'Lleftarrow;': '\u21da', + 'llhard;': '\u296b', + 'lltri;': '\u25fa', + 'Lmidot;': '\u013f', + 'lmidot;': '\u0140', + 'lmoust;': '\u23b0', + 'lmoustache;': '\u23b0', + 'lnap;': '\u2a89', + 'lnapprox;': '\u2a89', + 'lnE;': '\u2268', + 'lne;': '\u2a87', + 'lneq;': '\u2a87', + 'lneqq;': '\u2268', + 'lnsim;': '\u22e6', + 'loang;': '\u27ec', + 'loarr;': '\u21fd', + 'lobrk;': '\u27e6', + 'LongLeftArrow;': '\u27f5', + 'Longleftarrow;': '\u27f8', + 'longleftarrow;': '\u27f5', + 'LongLeftRightArrow;': '\u27f7', + 'Longleftrightarrow;': '\u27fa', + 'longleftrightarrow;': '\u27f7', + 'longmapsto;': '\u27fc', + 'LongRightArrow;': '\u27f6', + 'Longrightarrow;': '\u27f9', + 'longrightarrow;': '\u27f6', + 'looparrowleft;': '\u21ab', + 'looparrowright;': '\u21ac', + 'lopar;': '\u2985', + 'Lopf;': '\U0001d543', + 'lopf;': '\U0001d55d', + 'loplus;': '\u2a2d', + 'lotimes;': '\u2a34', + 'lowast;': '\u2217', + 'lowbar;': '_', + 'LowerLeftArrow;': '\u2199', + 'LowerRightArrow;': '\u2198', + 'loz;': '\u25ca', + 'lozenge;': '\u25ca', + 'lozf;': '\u29eb', + 'lpar;': '(', + 'lparlt;': '\u2993', + 'lrarr;': '\u21c6', + 'lrcorner;': '\u231f', + 'lrhar;': '\u21cb', + 'lrhard;': '\u296d', + 'lrm;': '\u200e', + 'lrtri;': '\u22bf', + 'lsaquo;': '\u2039', + 'Lscr;': '\u2112', + 'lscr;': '\U0001d4c1', + 'Lsh;': '\u21b0', + 'lsh;': '\u21b0', + 'lsim;': '\u2272', + 'lsime;': '\u2a8d', + 'lsimg;': '\u2a8f', + 'lsqb;': '[', + 'lsquo;': '\u2018', + 'lsquor;': '\u201a', + 'Lstrok;': '\u0141', + 'lstrok;': '\u0142', + 'LT': '<', + 'lt': '<', + 'LT;': '<', + 'Lt;': '\u226a', + 'lt;': '<', + 'ltcc;': '\u2aa6', + 'ltcir;': '\u2a79', + 'ltdot;': '\u22d6', + 'lthree;': '\u22cb', + 'ltimes;': '\u22c9', + 'ltlarr;': '\u2976', + 'ltquest;': '\u2a7b', + 'ltri;': '\u25c3', + 'ltrie;': '\u22b4', + 'ltrif;': '\u25c2', + 'ltrPar;': '\u2996', + 'lurdshar;': '\u294a', + 'luruhar;': '\u2966', + 'lvertneqq;': '\u2268\ufe00', + 'lvnE;': '\u2268\ufe00', + 'macr': '\xaf', + 'macr;': '\xaf', + 'male;': '\u2642', + 'malt;': '\u2720', + 'maltese;': '\u2720', + 'Map;': '\u2905', + 'map;': '\u21a6', + 'mapsto;': '\u21a6', + 'mapstodown;': '\u21a7', + 'mapstoleft;': '\u21a4', + 'mapstoup;': '\u21a5', + 'marker;': '\u25ae', + 'mcomma;': '\u2a29', + 'Mcy;': '\u041c', + 'mcy;': '\u043c', + 'mdash;': '\u2014', + 'mDDot;': '\u223a', + 'measuredangle;': '\u2221', + 'MediumSpace;': '\u205f', + 'Mellintrf;': '\u2133', + 'Mfr;': '\U0001d510', + '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', + 'MinusPlus;': '\u2213', + 'mlcp;': '\u2adb', + 'mldr;': '\u2026', + 'mnplus;': '\u2213', + 'models;': '\u22a7', + 'Mopf;': '\U0001d544', + 'mopf;': '\U0001d55e', + 'mp;': '\u2213', + 'Mscr;': '\u2133', + 'mscr;': '\U0001d4c2', + 'mstpos;': '\u223e', + 'Mu;': '\u039c', + 'mu;': '\u03bc', + 'multimap;': '\u22b8', + 'mumap;': '\u22b8', + 'nabla;': '\u2207', + 'Nacute;': '\u0143', + '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;': '\u0147', + 'ncaron;': '\u0148', + 'Ncedil;': '\u0145', + 'ncedil;': '\u0146', + 'ncong;': '\u2247', + 'ncongdot;': '\u2a6d\u0338', + 'ncup;': '\u2a42', + 'Ncy;': '\u041d', + 'ncy;': '\u043d', + 'ndash;': '\u2013', + 'ne;': '\u2260', + 'nearhk;': '\u2924', + 'neArr;': '\u21d7', + 'nearr;': '\u2197', + 'nearrow;': '\u2197', + 'nedot;': '\u2250\u0338', + 'NegativeMediumSpace;': '\u200b', + 'NegativeThickSpace;': '\u200b', + 'NegativeThinSpace;': '\u200b', + 'NegativeVeryThinSpace;': '\u200b', + 'nequiv;': '\u2262', + 'nesear;': '\u2928', + 'nesim;': '\u2242\u0338', + 'NestedGreaterGreater;': '\u226b', + 'NestedLessLess;': '\u226a', + 'NewLine;': '\n', + 'nexist;': '\u2204', + 'nexists;': '\u2204', + 'Nfr;': '\U0001d511', + 'nfr;': '\U0001d52b', + 'ngE;': '\u2267\u0338', + 'nge;': '\u2271', + 'ngeq;': '\u2271', + 'ngeqq;': '\u2267\u0338', + 'ngeqslant;': '\u2a7e\u0338', + 'nges;': '\u2a7e\u0338', + 'nGg;': '\u22d9\u0338', + 'ngsim;': '\u2275', + 'nGt;': '\u226b\u20d2', + 'ngt;': '\u226f', + 'ngtr;': '\u226f', + 'nGtv;': '\u226b\u0338', + 'nhArr;': '\u21ce', + 'nharr;': '\u21ae', + 'nhpar;': '\u2af2', + 'ni;': '\u220b', + 'nis;': '\u22fc', + 'nisd;': '\u22fa', + 'niv;': '\u220b', + 'NJcy;': '\u040a', + 'njcy;': '\u045a', + 'nlArr;': '\u21cd', + 'nlarr;': '\u219a', + 'nldr;': '\u2025', + 'nlE;': '\u2266\u0338', + 'nle;': '\u2270', + 'nLeftarrow;': '\u21cd', + 'nleftarrow;': '\u219a', + 'nLeftrightarrow;': '\u21ce', + 'nleftrightarrow;': '\u21ae', + 'nleq;': '\u2270', + 'nleqq;': '\u2266\u0338', + 'nleqslant;': '\u2a7d\u0338', + 'nles;': '\u2a7d\u0338', + 'nless;': '\u226e', + 'nLl;': '\u22d8\u0338', + 'nlsim;': '\u2274', + 'nLt;': '\u226a\u20d2', + 'nlt;': '\u226e', + 'nltri;': '\u22ea', + 'nltrie;': '\u22ec', + 'nLtv;': '\u226a\u0338', + 'nmid;': '\u2224', + 'NoBreak;': '\u2060', + 'NonBreakingSpace;': '\xa0', + 'Nopf;': '\u2115', + 'nopf;': '\U0001d55f', + 'not': '\xac', + 'Not;': '\u2aec', + 'not;': '\xac', + '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', + 'notin;': '\u2209', + 'notindot;': '\u22f5\u0338', + 'notinE;': '\u22f9\u0338', + 'notinva;': '\u2209', + 'notinvb;': '\u22f7', + 'notinvc;': '\u22f6', + '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', + 'notni;': '\u220c', + 'notniva;': '\u220c', + 'notnivb;': '\u22fe', + 'notnivc;': '\u22fd', + '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', + '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;': '\u21cf', + 'nrightarrow;': '\u219b', + 'nrtri;': '\u22eb', + 'nrtrie;': '\u22ed', + 'nsc;': '\u2281', + 'nsccue;': '\u22e1', + 'nsce;': '\u2ab0\u0338', + 'Nscr;': '\U0001d4a9', + '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': '\xd1', + 'ntilde': '\xf1', + 'Ntilde;': '\xd1', + 'ntilde;': '\xf1', + 'ntlg;': '\u2278', + 'ntriangleleft;': '\u22ea', + 'ntrianglelefteq;': '\u22ec', + 'ntriangleright;': '\u22eb', + 'ntrianglerighteq;': '\u22ed', + 'Nu;': '\u039d', + 'nu;': '\u03bd', + 'num;': '#', + 'numero;': '\u2116', + 'numsp;': '\u2007', + 'nvap;': '\u224d\u20d2', + 'nVDash;': '\u22af', + 'nVdash;': '\u22ae', + 'nvDash;': '\u22ad', + 'nvdash;': '\u22ac', + 'nvge;': '\u2265\u20d2', + 'nvgt;': '>\u20d2', + 'nvHarr;': '\u2904', + 'nvinfin;': '\u29de', + 'nvlArr;': '\u2902', + 'nvle;': '\u2264\u20d2', + 'nvlt;': '<\u20d2', + 'nvltrie;': '\u22b4\u20d2', + 'nvrArr;': '\u2903', + 'nvrtrie;': '\u22b5\u20d2', + 'nvsim;': '\u223c\u20d2', + 'nwarhk;': '\u2923', + 'nwArr;': '\u21d6', + 'nwarr;': '\u2196', + 'nwarrow;': '\u2196', + 'nwnear;': '\u2927', + 'Oacute': '\xd3', + 'oacute': '\xf3', + 'Oacute;': '\xd3', + 'oacute;': '\xf3', + 'oast;': '\u229b', + 'ocir;': '\u229a', + 'Ocirc': '\xd4', + 'ocirc': '\xf4', + 'Ocirc;': '\xd4', + 'ocirc;': '\xf4', + 'Ocy;': '\u041e', + 'ocy;': '\u043e', + 'odash;': '\u229d', + 'Odblac;': '\u0150', + 'odblac;': '\u0151', + 'odiv;': '\u2a38', + 'odot;': '\u2299', + 'odsold;': '\u29bc', + 'OElig;': '\u0152', + 'oelig;': '\u0153', + 'ofcir;': '\u29bf', + 'Ofr;': '\U0001d512', + 'ofr;': '\U0001d52c', + 'ogon;': '\u02db', + 'Ograve': '\xd2', + 'ograve': '\xf2', + 'Ograve;': '\xd2', + 'ograve;': '\xf2', + 'ogt;': '\u29c1', + 'ohbar;': '\u29b5', + 'ohm;': '\u03a9', + 'oint;': '\u222e', + 'olarr;': '\u21ba', + 'olcir;': '\u29be', + 'olcross;': '\u29bb', + 'oline;': '\u203e', + 'olt;': '\u29c0', + 'Omacr;': '\u014c', + 'omacr;': '\u014d', + 'Omega;': '\u03a9', + 'omega;': '\u03c9', + 'Omicron;': '\u039f', + 'omicron;': '\u03bf', + 'omid;': '\u29b6', + 'ominus;': '\u2296', + 'Oopf;': '\U0001d546', + 'oopf;': '\U0001d560', + 'opar;': '\u29b7', + 'OpenCurlyDoubleQuote;': '\u201c', + 'OpenCurlyQuote;': '\u2018', + 'operp;': '\u29b9', + 'oplus;': '\u2295', + 'Or;': '\u2a54', + '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', + 'oS;': '\u24c8', + 'Oscr;': '\U0001d4aa', + 'oscr;': '\u2134', + 'Oslash': '\xd8', + 'oslash': '\xf8', + 'Oslash;': '\xd8', + 'oslash;': '\xf8', + 'osol;': '\u2298', + 'Otilde': '\xd5', + 'otilde': '\xf5', + 'Otilde;': '\xd5', + 'otilde;': '\xf5', + 'Otimes;': '\u2a37', + 'otimes;': '\u2297', + 'otimesas;': '\u2a36', + 'Ouml': '\xd6', + 'ouml': '\xf6', + 'Ouml;': '\xd6', + 'ouml;': '\xf6', + 'ovbar;': '\u233d', + 'OverBar;': '\u203e', + 'OverBrace;': '\u23de', + 'OverBracket;': '\u23b4', + 'OverParenthesis;': '\u23dc', + 'par;': '\u2225', + 'para': '\xb6', + 'para;': '\xb6', + 'parallel;': '\u2225', + 'parsim;': '\u2af3', + 'parsl;': '\u2afd', + 'part;': '\u2202', + 'PartialD;': '\u2202', + 'Pcy;': '\u041f', + 'pcy;': '\u043f', + 'percnt;': '%', + 'period;': '.', + 'permil;': '\u2030', + 'perp;': '\u22a5', + 'pertenk;': '\u2031', + 'Pfr;': '\U0001d513', + 'pfr;': '\U0001d52d', + 'Phi;': '\u03a6', + 'phi;': '\u03c6', + 'phiv;': '\u03d5', + 'phmmat;': '\u2133', + 'phone;': '\u260e', + 'Pi;': '\u03a0', + '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', + 'PlusMinus;': '\xb1', + 'plusmn': '\xb1', + 'plusmn;': '\xb1', + 'plussim;': '\u2a26', + 'plustwo;': '\u2a27', + 'pm;': '\xb1', + 'Poincareplane;': '\u210c', + 'pointint;': '\u2a15', + 'Popf;': '\u2119', + 'popf;': '\U0001d561', + 'pound': '\xa3', + 'pound;': '\xa3', + 'Pr;': '\u2abb', + 'pr;': '\u227a', + 'prap;': '\u2ab7', + 'prcue;': '\u227c', + 'prE;': '\u2ab3', + 'pre;': '\u2aaf', + 'prec;': '\u227a', + 'precapprox;': '\u2ab7', + 'preccurlyeq;': '\u227c', + 'Precedes;': '\u227a', + 'PrecedesEqual;': '\u2aaf', + 'PrecedesSlantEqual;': '\u227c', + 'PrecedesTilde;': '\u227e', + 'preceq;': '\u2aaf', + 'precnapprox;': '\u2ab9', + 'precneqq;': '\u2ab5', + 'precnsim;': '\u22e8', + 'precsim;': '\u227e', + 'Prime;': '\u2033', + 'prime;': '\u2032', + 'primes;': '\u2119', + 'prnap;': '\u2ab9', + 'prnE;': '\u2ab5', + 'prnsim;': '\u22e8', + 'prod;': '\u220f', + 'Product;': '\u220f', + 'profalar;': '\u232e', + 'profline;': '\u2312', + 'profsurf;': '\u2313', + 'prop;': '\u221d', + 'Proportion;': '\u2237', + 'Proportional;': '\u221d', + 'propto;': '\u221d', + 'prsim;': '\u227e', + 'prurel;': '\u22b0', + 'Pscr;': '\U0001d4ab', + 'pscr;': '\U0001d4c5', + 'Psi;': '\u03a8', + 'psi;': '\u03c8', + 'puncsp;': '\u2008', + 'Qfr;': '\U0001d514', + 'qfr;': '\U0001d52e', + 'qint;': '\u2a0c', + 'Qopf;': '\u211a', + 'qopf;': '\U0001d562', + 'qprime;': '\u2057', + 'Qscr;': '\U0001d4ac', + 'qscr;': '\U0001d4c6', + 'quaternions;': '\u210d', + 'quatint;': '\u2a16', + 'quest;': '?', + 'questeq;': '\u225f', + 'QUOT': '"', + 'quot': '"', + 'QUOT;': '"', + 'quot;': '"', + 'rAarr;': '\u21db', + 'race;': '\u223d\u0331', + 'Racute;': '\u0154', + 'racute;': '\u0155', + 'radic;': '\u221a', + 'raemptyv;': '\u29b3', + 'Rang;': '\u27eb', + 'rang;': '\u27e9', + 'rangd;': '\u2992', + 'range;': '\u29a5', + 'rangle;': '\u27e9', + 'raquo': '\xbb', + 'raquo;': '\xbb', + 'Rarr;': '\u21a0', + 'rArr;': '\u21d2', + 'rarr;': '\u2192', + 'rarrap;': '\u2975', + 'rarrb;': '\u21e5', + 'rarrbfs;': '\u2920', + 'rarrc;': '\u2933', + 'rarrfs;': '\u291e', + 'rarrhk;': '\u21aa', + 'rarrlp;': '\u21ac', + 'rarrpl;': '\u2945', + 'rarrsim;': '\u2974', + 'Rarrtl;': '\u2916', + 'rarrtl;': '\u21a3', + 'rarrw;': '\u219d', + 'rAtail;': '\u291c', + 'ratail;': '\u291a', + 'ratio;': '\u2236', + 'rationals;': '\u211a', + 'RBarr;': '\u2910', + 'rBarr;': '\u290f', + 'rbarr;': '\u290d', + 'rbbrk;': '\u2773', + 'rbrace;': '}', + 'rbrack;': ']', + 'rbrke;': '\u298c', + 'rbrksld;': '\u298e', + 'rbrkslu;': '\u2990', + 'Rcaron;': '\u0158', + 'rcaron;': '\u0159', + 'Rcedil;': '\u0156', + 'rcedil;': '\u0157', + 'rceil;': '\u2309', + 'rcub;': '}', + 'Rcy;': '\u0420', + 'rcy;': '\u0440', + 'rdca;': '\u2937', + 'rdldhar;': '\u2969', + 'rdquo;': '\u201d', + 'rdquor;': '\u201d', + 'rdsh;': '\u21b3', + 'Re;': '\u211c', + 'real;': '\u211c', + 'realine;': '\u211b', + 'realpart;': '\u211c', + 'reals;': '\u211d', + 'rect;': '\u25ad', + 'REG': '\xae', + 'reg': '\xae', + 'REG;': '\xae', + 'reg;': '\xae', + 'ReverseElement;': '\u220b', + 'ReverseEquilibrium;': '\u21cb', + 'ReverseUpEquilibrium;': '\u296f', + 'rfisht;': '\u297d', + 'rfloor;': '\u230b', + 'Rfr;': '\u211c', + 'rfr;': '\U0001d52f', + 'rHar;': '\u2964', + 'rhard;': '\u21c1', + 'rharu;': '\u21c0', + 'rharul;': '\u296c', + 'Rho;': '\u03a1', + 'rho;': '\u03c1', + 'rhov;': '\u03f1', + 'RightAngleBracket;': '\u27e9', + 'RightArrow;': '\u2192', + 'Rightarrow;': '\u21d2', + 'rightarrow;': '\u2192', + 'RightArrowBar;': '\u21e5', + 'RightArrowLeftArrow;': '\u21c4', + 'rightarrowtail;': '\u21a3', + 'RightCeiling;': '\u2309', + 'RightDoubleBracket;': '\u27e7', + 'RightDownTeeVector;': '\u295d', + 'RightDownVector;': '\u21c2', + 'RightDownVectorBar;': '\u2955', + 'RightFloor;': '\u230b', + 'rightharpoondown;': '\u21c1', + 'rightharpoonup;': '\u21c0', + 'rightleftarrows;': '\u21c4', + 'rightleftharpoons;': '\u21cc', + 'rightrightarrows;': '\u21c9', + 'rightsquigarrow;': '\u219d', + 'RightTee;': '\u22a2', + 'RightTeeArrow;': '\u21a6', + 'RightTeeVector;': '\u295b', + 'rightthreetimes;': '\u22cc', + 'RightTriangle;': '\u22b3', + 'RightTriangleBar;': '\u29d0', + 'RightTriangleEqual;': '\u22b5', + 'RightUpDownVector;': '\u294f', + 'RightUpTeeVector;': '\u295c', + 'RightUpVector;': '\u21be', + 'RightUpVectorBar;': '\u2954', + 'RightVector;': '\u21c0', + 'RightVectorBar;': '\u2953', + '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;': '\u211d', + 'ropf;': '\U0001d563', + 'roplus;': '\u2a2e', + 'rotimes;': '\u2a35', + 'RoundImplies;': '\u2970', + 'rpar;': ')', + 'rpargt;': '\u2994', + 'rppolint;': '\u2a12', + 'rrarr;': '\u21c9', + 'Rrightarrow;': '\u21db', + 'rsaquo;': '\u203a', + 'Rscr;': '\u211b', + 'rscr;': '\U0001d4c7', + 'Rsh;': '\u21b1', + 'rsh;': '\u21b1', + 'rsqb;': ']', + 'rsquo;': '\u2019', + 'rsquor;': '\u2019', + 'rthree;': '\u22cc', + 'rtimes;': '\u22ca', + 'rtri;': '\u25b9', + 'rtrie;': '\u22b5', + 'rtrif;': '\u25b8', + 'rtriltri;': '\u29ce', + 'RuleDelayed;': '\u29f4', + 'ruluhar;': '\u2968', + 'rx;': '\u211e', + 'Sacute;': '\u015a', + 'sacute;': '\u015b', + 'sbquo;': '\u201a', + 'Sc;': '\u2abc', + 'sc;': '\u227b', + 'scap;': '\u2ab8', + 'Scaron;': '\u0160', + 'scaron;': '\u0161', + 'sccue;': '\u227d', + 'scE;': '\u2ab4', + 'sce;': '\u2ab0', + 'Scedil;': '\u015e', + 'scedil;': '\u015f', + 'Scirc;': '\u015c', + 'scirc;': '\u015d', + 'scnap;': '\u2aba', + 'scnE;': '\u2ab6', + 'scnsim;': '\u22e9', + 'scpolint;': '\u2a13', + 'scsim;': '\u227f', + 'Scy;': '\u0421', + 'scy;': '\u0441', + 'sdot;': '\u22c5', + 'sdotb;': '\u22a1', + 'sdote;': '\u2a66', + 'searhk;': '\u2925', + 'seArr;': '\u21d8', + 'searr;': '\u2198', + 'searrow;': '\u2198', + 'sect': '\xa7', + 'sect;': '\xa7', + 'semi;': ';', + 'seswar;': '\u2929', + 'setminus;': '\u2216', + 'setmn;': '\u2216', + 'sext;': '\u2736', + 'Sfr;': '\U0001d516', + 'sfr;': '\U0001d530', + 'sfrown;': '\u2322', + 'sharp;': '\u266f', + 'SHCHcy;': '\u0429', + 'shchcy;': '\u0449', + 'SHcy;': '\u0428', + 'shcy;': '\u0448', + 'ShortDownArrow;': '\u2193', + 'ShortLeftArrow;': '\u2190', + 'shortmid;': '\u2223', + 'shortparallel;': '\u2225', + 'ShortRightArrow;': '\u2192', + 'ShortUpArrow;': '\u2191', + 'shy': '\xad', + 'shy;': '\xad', + 'Sigma;': '\u03a3', + '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', + 'SmallCircle;': '\u2218', + 'smallsetminus;': '\u2216', + 'smashp;': '\u2a33', + 'smeparsl;': '\u29e4', + 'smid;': '\u2223', + 'smile;': '\u2323', + 'smt;': '\u2aaa', + 'smte;': '\u2aac', + 'smtes;': '\u2aac\ufe00', + 'SOFTcy;': '\u042c', + 'softcy;': '\u044c', + 'sol;': '/', + 'solb;': '\u29c4', + 'solbar;': '\u233f', + 'Sopf;': '\U0001d54a', + 'sopf;': '\U0001d564', + 'spades;': '\u2660', + 'spadesuit;': '\u2660', + 'spar;': '\u2225', + 'sqcap;': '\u2293', + 'sqcaps;': '\u2293\ufe00', + 'sqcup;': '\u2294', + 'sqcups;': '\u2294\ufe00', + 'Sqrt;': '\u221a', + 'sqsub;': '\u228f', + 'sqsube;': '\u2291', + 'sqsubset;': '\u228f', + 'sqsubseteq;': '\u2291', + 'sqsup;': '\u2290', + 'sqsupe;': '\u2292', + 'sqsupset;': '\u2290', + 'sqsupseteq;': '\u2292', + 'squ;': '\u25a1', + 'Square;': '\u25a1', + 'square;': '\u25a1', + 'SquareIntersection;': '\u2293', + 'SquareSubset;': '\u228f', + 'SquareSubsetEqual;': '\u2291', + 'SquareSuperset;': '\u2290', + 'SquareSupersetEqual;': '\u2292', + 'SquareUnion;': '\u2294', + 'squarf;': '\u25aa', + 'squf;': '\u25aa', + 'srarr;': '\u2192', + 'Sscr;': '\U0001d4ae', + 'sscr;': '\U0001d4c8', + 'ssetmn;': '\u2216', + 'ssmile;': '\u2323', + 'sstarf;': '\u22c6', + 'Star;': '\u22c6', + 'star;': '\u2606', + 'starf;': '\u2605', + 'straightepsilon;': '\u03f5', + 'straightphi;': '\u03d5', + 'strns;': '\xaf', + 'Sub;': '\u22d0', + 'sub;': '\u2282', + 'subdot;': '\u2abd', + 'subE;': '\u2ac5', + 'sube;': '\u2286', + 'subedot;': '\u2ac3', + 'submult;': '\u2ac1', + 'subnE;': '\u2acb', + 'subne;': '\u228a', + 'subplus;': '\u2abf', + 'subrarr;': '\u2979', + 'Subset;': '\u22d0', + 'subset;': '\u2282', + 'subseteq;': '\u2286', + 'subseteqq;': '\u2ac5', + 'SubsetEqual;': '\u2286', + 'subsetneq;': '\u228a', + 'subsetneqq;': '\u2acb', + 'subsim;': '\u2ac7', + 'subsub;': '\u2ad5', + 'subsup;': '\u2ad3', + 'succ;': '\u227b', + 'succapprox;': '\u2ab8', + 'succcurlyeq;': '\u227d', + 'Succeeds;': '\u227b', + 'SucceedsEqual;': '\u2ab0', + 'SucceedsSlantEqual;': '\u227d', + 'SucceedsTilde;': '\u227f', + 'succeq;': '\u2ab0', + 'succnapprox;': '\u2aba', + 'succneqq;': '\u2ab6', + 'succnsim;': '\u22e9', + 'succsim;': '\u227f', + 'SuchThat;': '\u220b', + 'Sum;': '\u2211', + 'sum;': '\u2211', + 'sung;': '\u266a', + 'sup1': '\xb9', + 'sup1;': '\xb9', + 'sup2': '\xb2', + 'sup2;': '\xb2', + 'sup3': '\xb3', + 'sup3;': '\xb3', + 'Sup;': '\u22d1', + 'sup;': '\u2283', + 'supdot;': '\u2abe', + 'supdsub;': '\u2ad8', + 'supE;': '\u2ac6', + 'supe;': '\u2287', + 'supedot;': '\u2ac4', + 'Superset;': '\u2283', + 'SupersetEqual;': '\u2287', + 'suphsol;': '\u27c9', + 'suphsub;': '\u2ad7', + 'suplarr;': '\u297b', + 'supmult;': '\u2ac2', + 'supnE;': '\u2acc', + 'supne;': '\u228b', + 'supplus;': '\u2ac0', + 'Supset;': '\u22d1', + 'supset;': '\u2283', + 'supseteq;': '\u2287', + 'supseteqq;': '\u2ac6', + 'supsetneq;': '\u228b', + 'supsetneqq;': '\u2acc', + 'supsim;': '\u2ac8', + 'supsub;': '\u2ad4', + 'supsup;': '\u2ad6', + 'swarhk;': '\u2926', + 'swArr;': '\u21d9', + 'swarr;': '\u2199', + 'swarrow;': '\u2199', + 'swnwar;': '\u292a', + 'szlig': '\xdf', + 'szlig;': '\xdf', + 'Tab;': '\t', + 'target;': '\u2316', + 'Tau;': '\u03a4', + 'tau;': '\u03c4', + 'tbrk;': '\u23b4', + 'Tcaron;': '\u0164', + 'tcaron;': '\u0165', + 'Tcedil;': '\u0162', + 'tcedil;': '\u0163', + 'Tcy;': '\u0422', + 'tcy;': '\u0442', + 'tdot;': '\u20db', + 'telrec;': '\u2315', + 'Tfr;': '\U0001d517', + 'tfr;': '\U0001d531', + 'there4;': '\u2234', + 'Therefore;': '\u2234', + 'therefore;': '\u2234', + 'Theta;': '\u0398', + 'theta;': '\u03b8', + 'thetasym;': '\u03d1', + 'thetav;': '\u03d1', + 'thickapprox;': '\u2248', + 'thicksim;': '\u223c', + 'ThickSpace;': '\u205f\u200a', + 'thinsp;': '\u2009', + 'ThinSpace;': '\u2009', + 'thkap;': '\u2248', + 'thksim;': '\u223c', + 'THORN': '\xde', + 'thorn': '\xfe', + 'THORN;': '\xde', + 'thorn;': '\xfe', + 'Tilde;': '\u223c', + 'tilde;': '\u02dc', + 'TildeEqual;': '\u2243', + 'TildeFullEqual;': '\u2245', + 'TildeTilde;': '\u2248', + 'times': '\xd7', + 'times;': '\xd7', + 'timesb;': '\u22a0', + 'timesbar;': '\u2a31', + 'timesd;': '\u2a30', + 'tint;': '\u222d', + 'toea;': '\u2928', + 'top;': '\u22a4', + 'topbot;': '\u2336', + 'topcir;': '\u2af1', + 'Topf;': '\U0001d54b', + 'topf;': '\U0001d565', + 'topfork;': '\u2ada', + 'tosa;': '\u2929', + 'tprime;': '\u2034', + 'TRADE;': '\u2122', + 'trade;': '\u2122', + 'triangle;': '\u25b5', + 'triangledown;': '\u25bf', + 'triangleleft;': '\u25c3', + 'trianglelefteq;': '\u22b4', + 'triangleq;': '\u225c', + 'triangleright;': '\u25b9', + 'trianglerighteq;': '\u22b5', + 'tridot;': '\u25ec', + 'trie;': '\u225c', + 'triminus;': '\u2a3a', + 'TripleDot;': '\u20db', + 'triplus;': '\u2a39', + 'trisb;': '\u29cd', + 'tritime;': '\u2a3b', + 'trpezium;': '\u23e2', + 'Tscr;': '\U0001d4af', + 'tscr;': '\U0001d4c9', + 'TScy;': '\u0426', + 'tscy;': '\u0446', + 'TSHcy;': '\u040b', + 'tshcy;': '\u045b', + 'Tstrok;': '\u0166', + 'tstrok;': '\u0167', + 'twixt;': '\u226c', + 'twoheadleftarrow;': '\u219e', + 'twoheadrightarrow;': '\u21a0', + 'Uacute': '\xda', + 'uacute': '\xfa', + 'Uacute;': '\xda', + 'uacute;': '\xfa', + 'Uarr;': '\u219f', + 'uArr;': '\u21d1', + 'uarr;': '\u2191', + 'Uarrocir;': '\u2949', + 'Ubrcy;': '\u040e', + 'ubrcy;': '\u045e', + 'Ubreve;': '\u016c', + 'ubreve;': '\u016d', + 'Ucirc': '\xdb', + 'ucirc': '\xfb', + 'Ucirc;': '\xdb', + 'ucirc;': '\xfb', + 'Ucy;': '\u0423', + 'ucy;': '\u0443', + 'udarr;': '\u21c5', + 'Udblac;': '\u0170', + 'udblac;': '\u0171', + 'udhar;': '\u296e', + 'ufisht;': '\u297e', + 'Ufr;': '\U0001d518', + 'ufr;': '\U0001d532', + 'Ugrave': '\xd9', + 'ugrave': '\xf9', + 'Ugrave;': '\xd9', + 'ugrave;': '\xf9', + 'uHar;': '\u2963', + 'uharl;': '\u21bf', + 'uharr;': '\u21be', + 'uhblk;': '\u2580', + 'ulcorn;': '\u231c', + 'ulcorner;': '\u231c', + 'ulcrop;': '\u230f', + 'ultri;': '\u25f8', + 'Umacr;': '\u016a', + 'umacr;': '\u016b', + 'uml': '\xa8', + 'uml;': '\xa8', + 'UnderBar;': '_', + 'UnderBrace;': '\u23df', + 'UnderBracket;': '\u23b5', + 'UnderParenthesis;': '\u23dd', + 'Union;': '\u22c3', + 'UnionPlus;': '\u228e', + 'Uogon;': '\u0172', + 'uogon;': '\u0173', + 'Uopf;': '\U0001d54c', + 'uopf;': '\U0001d566', + 'UpArrow;': '\u2191', + 'Uparrow;': '\u21d1', + 'uparrow;': '\u2191', + 'UpArrowBar;': '\u2912', + 'UpArrowDownArrow;': '\u21c5', + 'UpDownArrow;': '\u2195', + 'Updownarrow;': '\u21d5', + 'updownarrow;': '\u2195', + 'UpEquilibrium;': '\u296e', + 'upharpoonleft;': '\u21bf', + 'upharpoonright;': '\u21be', + 'uplus;': '\u228e', + 'UpperLeftArrow;': '\u2196', + 'UpperRightArrow;': '\u2197', + 'Upsi;': '\u03d2', + 'upsi;': '\u03c5', + 'upsih;': '\u03d2', + 'Upsilon;': '\u03a5', + 'upsilon;': '\u03c5', + 'UpTee;': '\u22a5', + 'UpTeeArrow;': '\u21a5', + 'upuparrows;': '\u21c8', + 'urcorn;': '\u231d', + 'urcorner;': '\u231d', + 'urcrop;': '\u230e', + 'Uring;': '\u016e', + 'uring;': '\u016f', + 'urtri;': '\u25f9', + 'Uscr;': '\U0001d4b0', + 'uscr;': '\U0001d4ca', + 'utdot;': '\u22f0', + 'Utilde;': '\u0168', + 'utilde;': '\u0169', + 'utri;': '\u25b5', + 'utrif;': '\u25b4', + 'uuarr;': '\u21c8', + 'Uuml': '\xdc', + 'uuml': '\xfc', + 'Uuml;': '\xdc', + 'uuml;': '\xfc', + 'uwangle;': '\u29a7', + 'vangrt;': '\u299c', + 'varepsilon;': '\u03f5', + 'varkappa;': '\u03f0', + 'varnothing;': '\u2205', + 'varphi;': '\u03d5', + 'varpi;': '\u03d6', + 'varpropto;': '\u221d', + 'vArr;': '\u21d5', + 'varr;': '\u2195', + 'varrho;': '\u03f1', + 'varsigma;': '\u03c2', + 'varsubsetneq;': '\u228a\ufe00', + 'varsubsetneqq;': '\u2acb\ufe00', + 'varsupsetneq;': '\u228b\ufe00', + 'varsupsetneqq;': '\u2acc\ufe00', + 'vartheta;': '\u03d1', + 'vartriangleleft;': '\u22b2', + 'vartriangleright;': '\u22b3', + 'Vbar;': '\u2aeb', + 'vBar;': '\u2ae8', + 'vBarv;': '\u2ae9', + 'Vcy;': '\u0412', + 'vcy;': '\u0432', + 'VDash;': '\u22ab', + 'Vdash;': '\u22a9', + 'vDash;': '\u22a8', + 'vdash;': '\u22a2', + 'Vdashl;': '\u2ae6', + 'Vee;': '\u22c1', + 'vee;': '\u2228', + 'veebar;': '\u22bb', + 'veeeq;': '\u225a', + 'vellip;': '\u22ee', + 'Verbar;': '\u2016', + 'verbar;': '|', + 'Vert;': '\u2016', + 'vert;': '|', + 'VerticalBar;': '\u2223', + 'VerticalLine;': '|', + 'VerticalSeparator;': '\u2758', + 'VerticalTilde;': '\u2240', + 'VeryThinSpace;': '\u200a', + 'Vfr;': '\U0001d519', + 'vfr;': '\U0001d533', + 'vltri;': '\u22b2', + 'vnsub;': '\u2282\u20d2', + 'vnsup;': '\u2283\u20d2', + 'Vopf;': '\U0001d54d', + 'vopf;': '\U0001d567', + 'vprop;': '\u221d', + 'vrtri;': '\u22b3', + 'Vscr;': '\U0001d4b1', + 'vscr;': '\U0001d4cb', + 'vsubnE;': '\u2acb\ufe00', + 'vsubne;': '\u228a\ufe00', + 'vsupnE;': '\u2acc\ufe00', + 'vsupne;': '\u228b\ufe00', + 'Vvdash;': '\u22aa', + 'vzigzag;': '\u299a', + 'Wcirc;': '\u0174', + 'wcirc;': '\u0175', + 'wedbar;': '\u2a5f', + 'Wedge;': '\u22c0', + 'wedge;': '\u2227', + 'wedgeq;': '\u2259', + 'weierp;': '\u2118', + 'Wfr;': '\U0001d51a', + 'wfr;': '\U0001d534', + 'Wopf;': '\U0001d54e', + 'wopf;': '\U0001d568', + 'wp;': '\u2118', + 'wr;': '\u2240', + 'wreath;': '\u2240', + 'Wscr;': '\U0001d4b2', + 'wscr;': '\U0001d4cc', + 'xcap;': '\u22c2', + 'xcirc;': '\u25ef', + 'xcup;': '\u22c3', + 'xdtri;': '\u25bd', + 'Xfr;': '\U0001d51b', + 'xfr;': '\U0001d535', + 'xhArr;': '\u27fa', + 'xharr;': '\u27f7', + 'Xi;': '\u039e', + 'xi;': '\u03be', + 'xlArr;': '\u27f8', + 'xlarr;': '\u27f5', + 'xmap;': '\u27fc', + 'xnis;': '\u22fb', + 'xodot;': '\u2a00', + 'Xopf;': '\U0001d54f', + 'xopf;': '\U0001d569', + 'xoplus;': '\u2a01', + 'xotime;': '\u2a02', + 'xrArr;': '\u27f9', + 'xrarr;': '\u27f6', + 'Xscr;': '\U0001d4b3', + 'xscr;': '\U0001d4cd', + 'xsqcup;': '\u2a06', + 'xuplus;': '\u2a04', + 'xutri;': '\u25b3', + 'xvee;': '\u22c1', + 'xwedge;': '\u22c0', + 'Yacute': '\xdd', + 'yacute': '\xfd', + 'Yacute;': '\xdd', + 'yacute;': '\xfd', + 'YAcy;': '\u042f', + 'yacy;': '\u044f', + 'Ycirc;': '\u0176', + 'ycirc;': '\u0177', + 'Ycy;': '\u042b', + 'ycy;': '\u044b', + 'yen': '\xa5', + 'yen;': '\xa5', + 'Yfr;': '\U0001d51c', + 'yfr;': '\U0001d536', + 'YIcy;': '\u0407', + 'yicy;': '\u0457', + 'Yopf;': '\U0001d550', + 'yopf;': '\U0001d56a', + 'Yscr;': '\U0001d4b4', + 'yscr;': '\U0001d4ce', + 'YUcy;': '\u042e', + 'yucy;': '\u044e', + 'yuml': '\xff', + 'Yuml;': '\u0178', + 'yuml;': '\xff', + 'Zacute;': '\u0179', + 'zacute;': '\u017a', + 'Zcaron;': '\u017d', + 'zcaron;': '\u017e', + 'Zcy;': '\u0417', + 'zcy;': '\u0437', + 'Zdot;': '\u017b', + 'zdot;': '\u017c', + 'zeetrf;': '\u2128', + 'ZeroWidthSpace;': '\u200b', + 'Zeta;': '\u0396', + 'zeta;': '\u03b6', + 'Zfr;': '\u2128', + 'zfr;': '\U0001d537', + 'ZHcy;': '\u0416', + 'zhcy;': '\u0436', + 'zigrarr;': '\u21dd', + 'Zopf;': '\u2124', + 'zopf;': '\U0001d56b', + 'Zscr;': '\U0001d4b5', + 'zscr;': '\U0001d4cf', + 'zwj;': '\u200d', + 'zwnj;': '\u200c', +} + + +class EntitySubstitution(object): + """The ability to substitute XML or HTML entities for certain characters.""" + + def _populate_class_variables(): + """Initialize variables used by this class to manage the plethora of + HTML5 named entities. + + This function returns a 3-tuple containing two dictionaries + and a regular expression: + + unicode_to_name - A mapping of Unicode strings like "⦨" to + entity names like "angmsdaa". When a single Unicode string has + multiple entity names, we try to choose the most commonly-used + name. + + name_to_unicode: A mapping of entity names like "angmsdaa" to + Unicode strings like "⦨". + + named_entity_re: A regular expression matching (almost) any + Unicode string that corresponds to an HTML5 named entity. + """ + unicode_to_name = {} + name_to_unicode = {} + + short_entities = set() + long_entities_by_first_character = defaultdict(set) + + for name_with_semicolon, character in sorted(html5.items()): + # "It is intentional, for legacy compatibility, that many + # code points have multiple character reference names. For + # example, some appear both with and without the trailing + # semicolon, or with different capitalizations." + # - https://html.spec.whatwg.org/multipage/named-characters.html#named-character-references + # + # The parsers are in charge of handling (or not) character + # references with no trailing semicolon, so we remove the + # semicolon whenever it appears. + if name_with_semicolon.endswith(';'): + name = name_with_semicolon[:-1] + else: + name = name_with_semicolon + + # When parsing HTML, we want to recognize any known named + # entity and convert it to a sequence of Unicode + # characters. + if name not in name_to_unicode: + name_to_unicode[name] = character + + # When _generating_ HTML, we want to recognize special + # character sequences that _could_ be converted to named + # entities. + unicode_to_name[character] = name + + # We also need to build a regular expression that lets us + # _find_ those characters in output strings so we can + # replace them. + # + # This is tricky, for two reasons. + + if (len(character) == 1 and ord(character) < 128 + and character not in '<>&'): + # First, it would be annoying to turn single ASCII + # characters like | into named entities like + # |. The exceptions are <>&, which we _must_ + # turn into named entities to produce valid HTML. + continue + + if len(character) > 1 and all(ord(x) < 128 for x in character): + # We also do not want to turn _combinations_ of ASCII + # characters like 'fj' into named entities like 'fj', + # though that's more debateable. + continue + + # Second, some named entities have a Unicode value that's + # a subset of the Unicode value for some _other_ named + # entity. As an example, \u2267' is ≧, + # but '\u2267\u0338' is ≧̸. Our regular + # expression needs to match the first two characters of + # "\u2267\u0338foo", but only the first character of + # "\u2267foo". + # + # In this step, we build two sets of characters that + # _eventually_ need to go into the regular expression. But + # we won't know exactly what the regular expression needs + # to look like until we've gone through the entire list of + # named entities. + if len(character) == 1: + short_entities.add(character) + else: + long_entities_by_first_character[character[0]].add(character) + + # Now that we've been through the entire list of entities, we + # can create a regular expression that matches any of them. + particles = set() + for short in short_entities: + long_versions = long_entities_by_first_character[short] + if not long_versions: + particles.add(short) + else: + ignore = "".join([x[1] for x in long_versions]) + # This finds, e.g. \u2267 but only if it is _not_ + # followed by \u0338. + particles.add("%s(?![%s])" % (short, ignore)) + + for long_entities in list(long_entities_by_first_character.values()): + for long_entity in long_entities: + particles.add(long_entity) + + re_definition = "(%s)" % "|".join(particles) + + # If an entity shows up in both html5 and codepoint2name, it's + # likely that HTML5 gives it several different names, such as + # 'rsquo' and 'rsquor'. When converting Unicode characters to + # named entities, the codepoint2name name should take + # precedence where possible, since that's the more easily + # recognizable one. + for codepoint, name in list(codepoint2name.items()): + character = chr(codepoint) + unicode_to_name[character] = name + + return unicode_to_name, name_to_unicode, re.compile(re_definition) + (CHARACTER_TO_HTML_ENTITY, HTML_ENTITY_TO_CHARACTER, + CHARACTER_TO_HTML_ENTITY_RE) = _populate_class_variables() + + CHARACTER_TO_XML_ENTITY = { + "'": "apos", + '"': "quot", + "&": "amp", + "<": "lt", + ">": "gt", + } + + BARE_AMPERSAND_OR_BRACKET = re.compile("([<>]|" + "&(?!#\\d+;|#x[0-9a-fA-F]+;|\\w+;)" + ")") + + AMPERSAND_OR_BRACKET = re.compile("([<>&])") + + @classmethod + def _substitute_html_entity(cls, matchobj): + """Used with a regular expression to substitute the + appropriate HTML entity for a special character string.""" + entity = cls.CHARACTER_TO_HTML_ENTITY.get(matchobj.group(0)) + return "&%s;" % entity + + @classmethod + def _substitute_xml_entity(cls, matchobj): + """Used with a regular expression to substitute the + appropriate XML entity for a special character string.""" + entity = cls.CHARACTER_TO_XML_ENTITY[matchobj.group(0)] + return "&%s;" % entity + + @classmethod + def quoted_attribute_value(self, value): + """Make a value into a quoted XML attribute, possibly escaping it. + + Most strings will be quoted using double quotes. + + Bob's Bar -> "Bob's Bar" + + If a string contains double quotes, it will be quoted using + single quotes. + + Welcome to "my bar" -> 'Welcome to "my bar"' + + If a string contains both single and double quotes, the + double quotes will be escaped, and the string will be quoted + using double quotes. + + Welcome to "Bob's Bar" -> "Welcome to "Bob's bar" + """ + quote_with = '"' + if '"' in value: + if "'" in value: + # The string contains both single and double + # quotes. Turn the double quotes into + # entities. We quote the double quotes rather than + # the single quotes because the entity name is + # """ whether this is HTML or XML. If we + # quoted the single quotes, we'd have to decide + # between ' and &squot;. + replace_with = """ + value = value.replace('"', replace_with) + else: + # There are double quotes but no single quotes. + # We can use single quotes to quote the attribute. + quote_with = "'" + return quote_with + value + quote_with + + @classmethod + def substitute_xml(cls, value, make_quoted_attribute=False): + """Substitute XML entities for special XML characters. + + :param value: A string to be substituted. The less-than sign + will become <, the greater-than sign will become >, + and any ampersands will become &. If you want ampersands + that appear to be part of an entity definition to be left + alone, use substitute_xml_containing_entities() instead. + + :param make_quoted_attribute: If True, then the string will be + quoted, as befits an attribute value. + """ + # Escape angle brackets and ampersands. + value = cls.AMPERSAND_OR_BRACKET.sub( + cls._substitute_xml_entity, value) + + if make_quoted_attribute: + value = cls.quoted_attribute_value(value) + return value + + @classmethod + def substitute_xml_containing_entities( + cls, value, make_quoted_attribute=False): + """Substitute XML entities for special XML characters. + + :param value: A string to be substituted. The less-than sign will + become <, the greater-than sign will become >, and any + ampersands that are not part of an entity defition will + become &. + + :param make_quoted_attribute: If True, then the string will be + quoted, as befits an attribute value. + """ + # Escape angle brackets, and ampersands that aren't part of + # entities. + value = cls.BARE_AMPERSAND_OR_BRACKET.sub( + cls._substitute_xml_entity, value) + + if make_quoted_attribute: + value = cls.quoted_attribute_value(value) + return value + + @classmethod + def substitute_html(cls, s): + """Replace certain Unicode characters with named HTML entities. + + This differs from data.encode(encoding, 'xmlcharrefreplace') + in that the goal is to make the result more readable (to those + with ASCII displays) rather than to recover from + errors. There's absolutely nothing wrong with a UTF-8 string + containg a LATIN SMALL LETTER E WITH ACUTE, but replacing that + character with "é" will make it more readable to some + people. + + :param s: A Unicode string. + """ + return cls.CHARACTER_TO_HTML_ENTITY_RE.sub( + cls._substitute_html_entity, s) + + +class EncodingDetector: + """Suggests a number of possible encodings for a bytestring. + + Order of precedence: + + 1. Encodings you specifically tell EncodingDetector to try first + (the known_definite_encodings argument to the constructor). + + 2. An encoding determined by sniffing the document's byte-order mark. + + 3. Encodings you specifically tell EncodingDetector to try if + byte-order mark sniffing fails (the user_encodings argument to the + constructor). + + 4. An encoding declared within the bytestring itself, either in an + XML declaration (if the bytestring is to be interpreted as an XML + document), or in a tag (if the bytestring is to be + interpreted as an HTML document.) + + 5. An encoding detected through textual analysis by chardet, + cchardet, or a similar external library. + + 4. UTF-8. + + 5. Windows-1252. + + """ + def __init__(self, markup, known_definite_encodings=None, + is_html=False, exclude_encodings=None, + user_encodings=None, override_encodings=None): + """Constructor. + + :param markup: Some markup in an unknown encoding. + + :param known_definite_encodings: When determining the encoding + of `markup`, these encodings will be tried first, in + order. In HTML terms, this corresponds to the "known + definite encoding" step defined here: + https://html.spec.whatwg.org/multipage/parsing.html#parsing-with-a-known-character-encoding + + :param user_encodings: These encodings will be tried after the + `known_definite_encodings` have been tried and failed, and + after an attempt to sniff the encoding by looking at a + byte order mark has failed. In HTML terms, this + corresponds to the step "user has explicitly instructed + the user agent to override the document's character + encoding", defined here: + https://html.spec.whatwg.org/multipage/parsing.html#determining-the-character-encoding + + :param override_encodings: A deprecated alias for + known_definite_encodings. Any encodings here will be tried + immediately after the encodings in + known_definite_encodings. + + :param is_html: If True, this markup is considered to be + HTML. Otherwise it's assumed to be XML. + + :param exclude_encodings: These encodings will not be tried, + even if they otherwise would be. + + """ + self.known_definite_encodings = list(known_definite_encodings or []) + if override_encodings: + self.known_definite_encodings += override_encodings + self.user_encodings = user_encodings or [] + exclude_encodings = exclude_encodings or [] + self.exclude_encodings = set([x.lower() for x in exclude_encodings]) + self.chardet_encoding = None + self.is_html = is_html + self.declared_encoding = None + + # First order of business: strip a byte-order mark. + self.markup, self.sniffed_encoding = self.strip_byte_order_mark(markup) + + def _usable(self, encoding, tried): + """Should we even bother to try this encoding? + + :param encoding: Name of an encoding. + :param tried: Encodings that have already been tried. This will be modified + as a side effect. + """ + if encoding is not None: + encoding = encoding.lower() + if encoding in self.exclude_encodings: + return False + if encoding not in tried: + tried.add(encoding) + return True + return False + + @property + def encodings(self): + """Yield a number of encodings that might work for this markup. + + :yield: A sequence of strings. + """ + tried = set() + + # First, try the known definite encodings + for e in self.known_definite_encodings: + if self._usable(e, tried): + yield e + + # Did the document originally start with a byte-order mark + # that indicated its encoding? + if self._usable(self.sniffed_encoding, tried): + yield self.sniffed_encoding + + # Sniffing the byte-order mark did nothing; try the user + # encodings. + for e in self.user_encodings: + if self._usable(e, tried): + yield e + + # Look within the document for an XML or HTML encoding + # declaration. + if self.declared_encoding is None: + self.declared_encoding = self.find_declared_encoding( + self.markup, self.is_html) + if self._usable(self.declared_encoding, tried): + yield self.declared_encoding + + # Use third-party character set detection to guess at the + # encoding. + if self.chardet_encoding is None: + self.chardet_encoding = chardet_dammit(self.markup) + if self._usable(self.chardet_encoding, tried): + yield self.chardet_encoding + + # As a last-ditch effort, try utf-8 and windows-1252. + for e in ('utf-8', 'windows-1252'): + if self._usable(e, tried): + yield e + + @classmethod + def strip_byte_order_mark(cls, data): + """If a byte-order mark is present, strip it and return the encoding it implies. + + :param data: Some markup. + :return: A 2-tuple (modified data, implied encoding) + """ + encoding = None + if isinstance(data, str): + # Unicode data cannot have a byte-order mark. + return data, encoding + if (len(data) >= 4) and (data[:2] == b'\xfe\xff') \ + and (data[2:4] != '\x00\x00'): + encoding = 'utf-16be' + data = data[2:] + elif (len(data) >= 4) and (data[:2] == b'\xff\xfe') \ + and (data[2:4] != '\x00\x00'): + encoding = 'utf-16le' + data = data[2:] + elif data[:3] == b'\xef\xbb\xbf': + encoding = 'utf-8' + data = data[3:] + elif data[:4] == b'\x00\x00\xfe\xff': + encoding = 'utf-32be' + data = data[4:] + elif data[:4] == b'\xff\xfe\x00\x00': + encoding = 'utf-32le' + data = data[4:] + return data, encoding + + @classmethod + def find_declared_encoding(cls, markup, is_html=False, search_entire_document=False): + """Given a document, tries to find its declared encoding. + + An XML encoding is declared at the beginning of the document. + + An HTML encoding is declared in a tag, hopefully near the + beginning of the document. + + :param markup: Some markup. + :param is_html: If True, this markup is considered to be HTML. Otherwise + it's assumed to be XML. + :param search_entire_document: Since an encoding is supposed to declared near the beginning + of the document, most of the time it's only necessary to search a few kilobytes of data. + Set this to True to force this method to search the entire document. + """ + if search_entire_document: + xml_endpos = html_endpos = len(markup) + else: + xml_endpos = 1024 + html_endpos = max(2048, int(len(markup) * 0.05)) + + if isinstance(markup, bytes): + res = encoding_res[bytes] + else: + res = encoding_res[str] + + xml_re = res['xml'] + html_re = res['html'] + declared_encoding = None + declared_encoding_match = xml_re.search(markup, endpos=xml_endpos) + if not declared_encoding_match and is_html: + declared_encoding_match = html_re.search(markup, endpos=html_endpos) + if declared_encoding_match is not None: + declared_encoding = declared_encoding_match.groups()[0] + if declared_encoding: + if isinstance(declared_encoding, bytes): + declared_encoding = declared_encoding.decode('ascii', 'replace') + return declared_encoding.lower() + return None + +class UnicodeDammit: + """A class for detecting the encoding of a *ML document and + converting it to a Unicode string. If the source encoding is + windows-1252, can replace MS smart quotes with their HTML or XML + equivalents.""" + + # This dictionary maps commonly seen values for "charset" in HTML + # meta tags to the corresponding Python codec names. It only covers + # values that aren't in Python's aliases and can't be determined + # by the heuristics in find_codec. + CHARSET_ALIASES = {"macintosh": "mac-roman", + "x-sjis": "shift-jis"} + + ENCODINGS_WITH_SMART_QUOTES = [ + "windows-1252", + "iso-8859-1", + "iso-8859-2", + ] + + def __init__(self, markup, known_definite_encodings=[], + smart_quotes_to=None, is_html=False, exclude_encodings=[], + user_encodings=None, override_encodings=None + ): + """Constructor. + + :param markup: A bytestring representing markup in an unknown encoding. + + :param known_definite_encodings: When determining the encoding + of `markup`, these encodings will be tried first, in + order. In HTML terms, this corresponds to the "known + definite encoding" step defined here: + https://html.spec.whatwg.org/multipage/parsing.html#parsing-with-a-known-character-encoding + + :param user_encodings: These encodings will be tried after the + `known_definite_encodings` have been tried and failed, and + after an attempt to sniff the encoding by looking at a + byte order mark has failed. In HTML terms, this + corresponds to the step "user has explicitly instructed + the user agent to override the document's character + encoding", defined here: + https://html.spec.whatwg.org/multipage/parsing.html#determining-the-character-encoding + + :param override_encodings: A deprecated alias for + known_definite_encodings. Any encodings here will be tried + immediately after the encodings in + known_definite_encodings. + + :param smart_quotes_to: By default, Microsoft smart quotes will, like all other characters, be converted + to Unicode characters. Setting this to 'ascii' will convert them to ASCII quotes instead. + Setting it to 'xml' will convert them to XML entity references, and setting it to 'html' + will convert them to HTML entity references. + :param is_html: If True, this markup is considered to be HTML. Otherwise + it's assumed to be XML. + :param exclude_encodings: These encodings will not be considered, even + if the sniffing code thinks they might make sense. + + """ + self.smart_quotes_to = smart_quotes_to + self.tried_encodings = [] + self.contains_replacement_characters = False + self.is_html = is_html + self.log = logging.getLogger(__name__) + self.detector = EncodingDetector( + markup, known_definite_encodings, is_html, exclude_encodings, + user_encodings, override_encodings + ) + + # Short-circuit if the data is in Unicode to begin with. + if isinstance(markup, str) or markup == '': + self.markup = markup + self.unicode_markup = str(markup) + self.original_encoding = None + return + + # The encoding detector may have stripped a byte-order mark. + # Use the stripped markup from this point on. + self.markup = self.detector.markup + + u = None + for encoding in self.detector.encodings: + markup = self.detector.markup + u = self._convert_from(encoding) + if u is not None: + break + + if not u: + # None of the encodings worked. As an absolute last resort, + # try them again with character replacement. + + for encoding in self.detector.encodings: + if encoding != "ascii": + u = self._convert_from(encoding, "replace") + if u is not None: + self.log.warning( + "Some characters could not be decoded, and were " + "replaced with REPLACEMENT CHARACTER." + ) + self.contains_replacement_characters = True + break + + # If none of that worked, we could at this point force it to + # ASCII, but that would destroy so much data that I think + # giving up is better. + self.unicode_markup = u + if not u: + self.original_encoding = None + + def _sub_ms_char(self, match): + """Changes a MS smart quote character to an XML or HTML + entity, or an ASCII character.""" + orig = match.group(1) + if self.smart_quotes_to == 'ascii': + sub = self.MS_CHARS_TO_ASCII.get(orig).encode() + else: + sub = self.MS_CHARS.get(orig) + if type(sub) == tuple: + if self.smart_quotes_to == 'xml': + sub = '&#x'.encode() + sub[1].encode() + ';'.encode() + else: + sub = '&'.encode() + sub[0].encode() + ';'.encode() + else: + sub = sub.encode() + return sub + + def _convert_from(self, proposed, errors="strict"): + """Attempt to convert the markup to the proposed encoding. + + :param proposed: The name of a character encoding. + """ + proposed = self.find_codec(proposed) + if not proposed or (proposed, errors) in self.tried_encodings: + return None + self.tried_encodings.append((proposed, errors)) + markup = self.markup + # Convert smart quotes to HTML if coming from an encoding + # that might have them. + if (self.smart_quotes_to is not None + and proposed in self.ENCODINGS_WITH_SMART_QUOTES): + smart_quotes_re = b"([\x80-\x9f])" + smart_quotes_compiled = re.compile(smart_quotes_re) + markup = smart_quotes_compiled.sub(self._sub_ms_char, markup) + + try: + #print("Trying to convert document to %s (errors=%s)" % ( + # proposed, errors)) + u = self._to_unicode(markup, proposed, errors) + self.markup = u + self.original_encoding = proposed + except Exception as e: + #print("That didn't work!") + #print(e) + return None + #print("Correct encoding: %s" % proposed) + return self.markup + + def _to_unicode(self, data, encoding, errors="strict"): + """Given a string and its encoding, decodes the string into Unicode. + + :param encoding: The name of an encoding. + """ + return str(data, encoding, errors) + + @property + def declared_html_encoding(self): + """If the markup is an HTML document, returns the encoding declared _within_ + the document. + """ + if not self.is_html: + return None + return self.detector.declared_encoding + + def find_codec(self, charset): + """Convert the name of a character set to a codec name. + + :param charset: The name of a character set. + :return: The name of a codec. + """ + value = (self._codec(self.CHARSET_ALIASES.get(charset, charset)) + or (charset and self._codec(charset.replace("-", ""))) + or (charset and self._codec(charset.replace("-", "_"))) + or (charset and charset.lower()) + or charset + ) + if value: + return value.lower() + return None + + def _codec(self, charset): + if not charset: + return charset + codec = None + try: + codecs.lookup(charset) + codec = charset + except (LookupError, ValueError): + pass + return codec + + + # A partial mapping of ISO-Latin-1 to HTML entities/XML numeric entities. + MS_CHARS = {b'\x80': ('euro', '20AC'), + b'\x81': ' ', + b'\x82': ('sbquo', '201A'), + b'\x83': ('fnof', '192'), + b'\x84': ('bdquo', '201E'), + b'\x85': ('hellip', '2026'), + b'\x86': ('dagger', '2020'), + b'\x87': ('Dagger', '2021'), + b'\x88': ('circ', '2C6'), + b'\x89': ('permil', '2030'), + b'\x8A': ('Scaron', '160'), + b'\x8B': ('lsaquo', '2039'), + b'\x8C': ('OElig', '152'), + b'\x8D': '?', + b'\x8E': ('#x17D', '17D'), + b'\x8F': '?', + b'\x90': '?', + b'\x91': ('lsquo', '2018'), + b'\x92': ('rsquo', '2019'), + b'\x93': ('ldquo', '201C'), + b'\x94': ('rdquo', '201D'), + b'\x95': ('bull', '2022'), + b'\x96': ('ndash', '2013'), + b'\x97': ('mdash', '2014'), + b'\x98': ('tilde', '2DC'), + b'\x99': ('trade', '2122'), + b'\x9a': ('scaron', '161'), + b'\x9b': ('rsaquo', '203A'), + b'\x9c': ('oelig', '153'), + b'\x9d': '?', + b'\x9e': ('#x17E', '17E'), + b'\x9f': ('Yuml', ''),} + + # A parochial partial mapping of ISO-Latin-1 to ASCII. Contains + # horrors like stripping diacritical marks to turn á into a, but also + # contains non-horrors like turning “ into ". + MS_CHARS_TO_ASCII = { + b'\x80' : 'EUR', + b'\x81' : ' ', + b'\x82' : ',', + b'\x83' : 'f', + b'\x84' : ',,', + b'\x85' : '...', + b'\x86' : '+', + b'\x87' : '++', + b'\x88' : '^', + b'\x89' : '%', + b'\x8a' : 'S', + b'\x8b' : '<', + b'\x8c' : 'OE', + b'\x8d' : '?', + b'\x8e' : 'Z', + b'\x8f' : '?', + b'\x90' : '?', + b'\x91' : "'", + b'\x92' : "'", + b'\x93' : '"', + b'\x94' : '"', + b'\x95' : '*', + b'\x96' : '-', + b'\x97' : '--', + b'\x98' : '~', + b'\x99' : '(TM)', + b'\x9a' : 's', + b'\x9b' : '>', + b'\x9c' : 'oe', + b'\x9d' : '?', + b'\x9e' : 'z', + b'\x9f' : 'Y', + b'\xa0' : ' ', + b'\xa1' : '!', + b'\xa2' : 'c', + b'\xa3' : 'GBP', + b'\xa4' : '$', #This approximation is especially parochial--this is the + #generic currency symbol. + b'\xa5' : 'YEN', + b'\xa6' : '|', + b'\xa7' : 'S', + b'\xa8' : '..', + b'\xa9' : '', + b'\xaa' : '(th)', + b'\xab' : '<<', + b'\xac' : '!', + b'\xad' : ' ', + b'\xae' : '(R)', + b'\xaf' : '-', + b'\xb0' : 'o', + b'\xb1' : '+-', + b'\xb2' : '2', + b'\xb3' : '3', + b'\xb4' : ("'", 'acute'), + b'\xb5' : 'u', + b'\xb6' : 'P', + b'\xb7' : '*', + b'\xb8' : ',', + b'\xb9' : '1', + b'\xba' : '(th)', + b'\xbb' : '>>', + b'\xbc' : '1/4', + b'\xbd' : '1/2', + b'\xbe' : '3/4', + b'\xbf' : '?', + b'\xc0' : 'A', + b'\xc1' : 'A', + b'\xc2' : 'A', + b'\xc3' : 'A', + b'\xc4' : 'A', + b'\xc5' : 'A', + b'\xc6' : 'AE', + b'\xc7' : 'C', + b'\xc8' : 'E', + b'\xc9' : 'E', + b'\xca' : 'E', + b'\xcb' : 'E', + b'\xcc' : 'I', + b'\xcd' : 'I', + b'\xce' : 'I', + b'\xcf' : 'I', + b'\xd0' : 'D', + b'\xd1' : 'N', + b'\xd2' : 'O', + b'\xd3' : 'O', + b'\xd4' : 'O', + b'\xd5' : 'O', + b'\xd6' : 'O', + b'\xd7' : '*', + b'\xd8' : 'O', + b'\xd9' : 'U', + b'\xda' : 'U', + b'\xdb' : 'U', + b'\xdc' : 'U', + b'\xdd' : 'Y', + b'\xde' : 'b', + b'\xdf' : 'B', + b'\xe0' : 'a', + b'\xe1' : 'a', + b'\xe2' : 'a', + b'\xe3' : 'a', + b'\xe4' : 'a', + b'\xe5' : 'a', + b'\xe6' : 'ae', + b'\xe7' : 'c', + b'\xe8' : 'e', + b'\xe9' : 'e', + b'\xea' : 'e', + b'\xeb' : 'e', + b'\xec' : 'i', + b'\xed' : 'i', + b'\xee' : 'i', + b'\xef' : 'i', + b'\xf0' : 'o', + b'\xf1' : 'n', + b'\xf2' : 'o', + b'\xf3' : 'o', + b'\xf4' : 'o', + b'\xf5' : 'o', + b'\xf6' : 'o', + b'\xf7' : '/', + b'\xf8' : 'o', + b'\xf9' : 'u', + b'\xfa' : 'u', + b'\xfb' : 'u', + b'\xfc' : 'u', + b'\xfd' : 'y', + b'\xfe' : 'b', + b'\xff' : 'y', + } + + # A map used when removing rogue Windows-1252/ISO-8859-1 + # characters in otherwise UTF-8 documents. + # + # Note that \x81, \x8d, \x8f, \x90, and \x9d are undefined in + # Windows-1252. + WINDOWS_1252_TO_UTF8 = { + 0x80 : b'\xe2\x82\xac', # € + 0x82 : b'\xe2\x80\x9a', # ‚ + 0x83 : b'\xc6\x92', # Æ’ + 0x84 : b'\xe2\x80\x9e', # „ + 0x85 : b'\xe2\x80\xa6', # … + 0x86 : b'\xe2\x80\xa0', # † + 0x87 : b'\xe2\x80\xa1', # ‡ + 0x88 : b'\xcb\x86', # ˆ + 0x89 : b'\xe2\x80\xb0', # ‰ + 0x8a : b'\xc5\xa0', # Å  + 0x8b : b'\xe2\x80\xb9', # ‹ + 0x8c : b'\xc5\x92', # Å’ + 0x8e : b'\xc5\xbd', # Ž + 0x91 : b'\xe2\x80\x98', # ‘ + 0x92 : b'\xe2\x80\x99', # ’ + 0x93 : b'\xe2\x80\x9c', # “ + 0x94 : b'\xe2\x80\x9d', # †+ 0x95 : b'\xe2\x80\xa2', # • + 0x96 : b'\xe2\x80\x93', # – + 0x97 : b'\xe2\x80\x94', # — + 0x98 : b'\xcb\x9c', # Ëœ + 0x99 : b'\xe2\x84\xa2', # â„¢ + 0x9a : b'\xc5\xa1', # Å¡ + 0x9b : b'\xe2\x80\xba', # › + 0x9c : b'\xc5\x93', # Å“ + 0x9e : b'\xc5\xbe', # ž + 0x9f : b'\xc5\xb8', # Ÿ + 0xa0 : b'\xc2\xa0', #   + 0xa1 : b'\xc2\xa1', # ¡ + 0xa2 : b'\xc2\xa2', # ¢ + 0xa3 : b'\xc2\xa3', # £ + 0xa4 : b'\xc2\xa4', # ¤ + 0xa5 : b'\xc2\xa5', # Â¥ + 0xa6 : b'\xc2\xa6', # ¦ + 0xa7 : b'\xc2\xa7', # § + 0xa8 : b'\xc2\xa8', # ¨ + 0xa9 : b'\xc2\xa9', # © + 0xaa : b'\xc2\xaa', # ª + 0xab : b'\xc2\xab', # « + 0xac : b'\xc2\xac', # ¬ + 0xad : b'\xc2\xad', # ­ + 0xae : b'\xc2\xae', # ® + 0xaf : b'\xc2\xaf', # ¯ + 0xb0 : b'\xc2\xb0', # ° + 0xb1 : b'\xc2\xb1', # ± + 0xb2 : b'\xc2\xb2', # ² + 0xb3 : b'\xc2\xb3', # ³ + 0xb4 : b'\xc2\xb4', # ´ + 0xb5 : b'\xc2\xb5', # µ + 0xb6 : b'\xc2\xb6', # ¶ + 0xb7 : b'\xc2\xb7', # · + 0xb8 : b'\xc2\xb8', # ¸ + 0xb9 : b'\xc2\xb9', # ¹ + 0xba : b'\xc2\xba', # º + 0xbb : b'\xc2\xbb', # » + 0xbc : b'\xc2\xbc', # ¼ + 0xbd : b'\xc2\xbd', # ½ + 0xbe : b'\xc2\xbe', # ¾ + 0xbf : b'\xc2\xbf', # ¿ + 0xc0 : b'\xc3\x80', # À + 0xc1 : b'\xc3\x81', # à + 0xc2 : b'\xc3\x82', #  + 0xc3 : b'\xc3\x83', # à + 0xc4 : b'\xc3\x84', # Ä + 0xc5 : b'\xc3\x85', # Ã… + 0xc6 : b'\xc3\x86', # Æ + 0xc7 : b'\xc3\x87', # Ç + 0xc8 : b'\xc3\x88', # È + 0xc9 : b'\xc3\x89', # É + 0xca : b'\xc3\x8a', # Ê + 0xcb : b'\xc3\x8b', # Ë + 0xcc : b'\xc3\x8c', # ÃŒ + 0xcd : b'\xc3\x8d', # à + 0xce : b'\xc3\x8e', # ÃŽ + 0xcf : b'\xc3\x8f', # à + 0xd0 : b'\xc3\x90', # à + 0xd1 : b'\xc3\x91', # Ñ + 0xd2 : b'\xc3\x92', # Ã’ + 0xd3 : b'\xc3\x93', # Ó + 0xd4 : b'\xc3\x94', # Ô + 0xd5 : b'\xc3\x95', # Õ + 0xd6 : b'\xc3\x96', # Ö + 0xd7 : b'\xc3\x97', # × + 0xd8 : b'\xc3\x98', # Ø + 0xd9 : b'\xc3\x99', # Ù + 0xda : b'\xc3\x9a', # Ú + 0xdb : b'\xc3\x9b', # Û + 0xdc : b'\xc3\x9c', # Ãœ + 0xdd : b'\xc3\x9d', # à + 0xde : b'\xc3\x9e', # Þ + 0xdf : b'\xc3\x9f', # ß + 0xe0 : b'\xc3\xa0', # à + 0xe1 : b'\xa1', # á + 0xe2 : b'\xc3\xa2', # â + 0xe3 : b'\xc3\xa3', # ã + 0xe4 : b'\xc3\xa4', # ä + 0xe5 : b'\xc3\xa5', # Ã¥ + 0xe6 : b'\xc3\xa6', # æ + 0xe7 : b'\xc3\xa7', # ç + 0xe8 : b'\xc3\xa8', # è + 0xe9 : b'\xc3\xa9', # é + 0xea : b'\xc3\xaa', # ê + 0xeb : b'\xc3\xab', # ë + 0xec : b'\xc3\xac', # ì + 0xed : b'\xc3\xad', # í + 0xee : b'\xc3\xae', # î + 0xef : b'\xc3\xaf', # ï + 0xf0 : b'\xc3\xb0', # ð + 0xf1 : b'\xc3\xb1', # ñ + 0xf2 : b'\xc3\xb2', # ò + 0xf3 : b'\xc3\xb3', # ó + 0xf4 : b'\xc3\xb4', # ô + 0xf5 : b'\xc3\xb5', # õ + 0xf6 : b'\xc3\xb6', # ö + 0xf7 : b'\xc3\xb7', # ÷ + 0xf8 : b'\xc3\xb8', # ø + 0xf9 : b'\xc3\xb9', # ù + 0xfa : b'\xc3\xba', # ú + 0xfb : b'\xc3\xbb', # û + 0xfc : b'\xc3\xbc', # ü + 0xfd : b'\xc3\xbd', # ý + 0xfe : b'\xc3\xbe', # þ + } + + MULTIBYTE_MARKERS_AND_SIZES = [ + (0xc2, 0xdf, 2), # 2-byte characters start with a byte C2-DF + (0xe0, 0xef, 3), # 3-byte characters start with E0-EF + (0xf0, 0xf4, 4), # 4-byte characters start with F0-F4 + ] + + FIRST_MULTIBYTE_MARKER = MULTIBYTE_MARKERS_AND_SIZES[0][0] + LAST_MULTIBYTE_MARKER = MULTIBYTE_MARKERS_AND_SIZES[-1][1] + + @classmethod + def detwingle(cls, in_bytes, main_encoding="utf8", + embedded_encoding="windows-1252"): + """Fix characters from one encoding embedded in some other encoding. + + Currently the only situation supported is Windows-1252 (or its + subset ISO-8859-1), embedded in UTF-8. + + :param in_bytes: A bytestring that you suspect contains + characters from multiple encodings. Note that this _must_ + be a bytestring. If you've already converted the document + to Unicode, you're too late. + :param main_encoding: The primary encoding of `in_bytes`. + :param embedded_encoding: The encoding that was used to embed characters + in the main document. + :return: A bytestring in which `embedded_encoding` + characters have been converted to their `main_encoding` + equivalents. + """ + if embedded_encoding.replace('_', '-').lower() not in ( + 'windows-1252', 'windows_1252'): + raise NotImplementedError( + "Windows-1252 and ISO-8859-1 are the only currently supported " + "embedded encodings.") + + if main_encoding.lower() not in ('utf8', 'utf-8'): + raise NotImplementedError( + "UTF-8 is the only currently supported main encoding.") + + byte_chunks = [] + + chunk_start = 0 + pos = 0 + while pos < len(in_bytes): + byte = in_bytes[pos] + if not isinstance(byte, int): + # Python 2.x + byte = ord(byte) + if (byte >= cls.FIRST_MULTIBYTE_MARKER + and byte <= cls.LAST_MULTIBYTE_MARKER): + # This is the start of a UTF-8 multibyte character. Skip + # to the end. + for start, end, size in cls.MULTIBYTE_MARKERS_AND_SIZES: + if byte >= start and byte <= end: + pos += size + break + elif byte >= 0x80 and byte in cls.WINDOWS_1252_TO_UTF8: + # We found a Windows-1252 character! + # Save the string up to this point as a chunk. + byte_chunks.append(in_bytes[chunk_start:pos]) + + # Now translate the Windows-1252 character into UTF-8 + # and add it as another, one-byte chunk. + byte_chunks.append(cls.WINDOWS_1252_TO_UTF8[byte]) + pos += 1 + chunk_start = pos + else: + # Go on to the next character. + pos += 1 + if chunk_start == 0: + # The string is unchanged. + return in_bytes + else: + # Store the final chunk. + byte_chunks.append(in_bytes[chunk_start:]) + return b''.join(byte_chunks) + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/diagnose.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/diagnose.py new file mode 100644 index 00000000..500e92df --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/diagnose.py @@ -0,0 +1,242 @@ +"""Diagnostic functions, mainly for use when doing tech support.""" + +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +import cProfile +from io import StringIO +from html.parser import HTMLParser +import bs4 +from bs4 import BeautifulSoup, __version__ +from bs4.builder import builder_registry + +import os +import pstats +import random +import tempfile +import time +import traceback +import sys +import cProfile + +def diagnose(data): + """Diagnostic suite for isolating common problems. + + :param data: A string containing markup that needs to be explained. + :return: None; diagnostics are printed to standard output. + """ + print(("Diagnostic running on Beautiful Soup %s" % __version__)) + print(("Python version %s" % sys.version)) + + basic_parsers = ["html.parser", "html5lib", "lxml"] + for name in basic_parsers: + for builder in builder_registry.builders: + if name in builder.features: + break + else: + basic_parsers.remove(name) + print(( + "I noticed that %s is not installed. Installing it may help." % + name)) + + if 'lxml' in basic_parsers: + basic_parsers.append("lxml-xml") + try: + from lxml import etree + print(("Found lxml version %s" % ".".join(map(str,etree.LXML_VERSION)))) + except ImportError as e: + print( + "lxml is not installed or couldn't be imported.") + + + if 'html5lib' in basic_parsers: + try: + import html5lib + print(("Found html5lib version %s" % html5lib.__version__)) + except ImportError as e: + print( + "html5lib is not installed or couldn't be imported.") + + if hasattr(data, 'read'): + data = data.read() + elif data.startswith("http:") or data.startswith("https:"): + print(('"%s" looks like a URL. Beautiful Soup is not an HTTP client.' % data)) + print("You need to use some other library to get the document behind the URL, and feed that document to Beautiful Soup.") + return + else: + try: + if os.path.exists(data): + print(('"%s" looks like a filename. Reading data from the file.' % data)) + with open(data) as fp: + data = fp.read() + except ValueError: + # This can happen on some platforms when the 'filename' is + # too long. Assume it's data and not a filename. + pass + print("") + + for parser in basic_parsers: + print(("Trying to parse your markup with %s" % parser)) + success = False + try: + soup = BeautifulSoup(data, features=parser) + success = True + except Exception as e: + print(("%s could not parse the markup." % parser)) + traceback.print_exc() + if success: + print(("Here's what %s did with the markup:" % parser)) + print((soup.prettify())) + + print(("-" * 80)) + +def lxml_trace(data, html=True, **kwargs): + """Print out the lxml events that occur during parsing. + + This lets you see how lxml parses a document when no Beautiful + Soup code is running. You can use this to determine whether + an lxml-specific problem is in Beautiful Soup's lxml tree builders + or in lxml itself. + + :param data: Some markup. + :param html: If True, markup will be parsed with lxml's HTML parser. + if False, lxml's XML parser will be used. + """ + from lxml import etree + for event, element in etree.iterparse(StringIO(data), html=html, **kwargs): + print(("%s, %4s, %s" % (event, element.tag, element.text))) + +class AnnouncingParser(HTMLParser): + """Subclass of HTMLParser that announces parse events, without doing + anything else. + + You can use this to get a picture of how html.parser sees a given + document. The easiest way to do this is to call `htmlparser_trace`. + """ + + def _p(self, s): + print(s) + + def handle_starttag(self, name, attrs): + self._p("%s START" % name) + + def handle_endtag(self, name): + self._p("%s END" % name) + + def handle_data(self, data): + self._p("%s DATA" % data) + + def handle_charref(self, name): + self._p("%s CHARREF" % name) + + def handle_entityref(self, name): + self._p("%s ENTITYREF" % name) + + def handle_comment(self, data): + self._p("%s COMMENT" % data) + + def handle_decl(self, data): + self._p("%s DECL" % data) + + def unknown_decl(self, data): + self._p("%s UNKNOWN-DECL" % data) + + def handle_pi(self, data): + self._p("%s PI" % data) + +def htmlparser_trace(data): + """Print out the HTMLParser events that occur during parsing. + + This lets you see how HTMLParser parses a document when no + Beautiful Soup code is running. + + :param data: Some markup. + """ + parser = AnnouncingParser() + parser.feed(data) + +_vowels = "aeiou" +_consonants = "bcdfghjklmnpqrstvwxyz" + +def rword(length=5): + "Generate a random word-like string." + s = '' + for i in range(length): + if i % 2 == 0: + t = _consonants + else: + t = _vowels + s += random.choice(t) + return s + +def rsentence(length=4): + "Generate a random sentence-like string." + return " ".join(rword(random.randint(4,9)) for i in range(length)) + +def rdoc(num_elements=1000): + """Randomly generate an invalid HTML document.""" + tag_names = ['p', 'div', 'span', 'i', 'b', 'script', 'table'] + elements = [] + for i in range(num_elements): + choice = random.randint(0,3) + if choice == 0: + # New tag. + tag_name = random.choice(tag_names) + elements.append("<%s>" % tag_name) + elif choice == 1: + elements.append(rsentence(random.randint(1,4))) + elif choice == 2: + # Close a tag. + tag_name = random.choice(tag_names) + elements.append("" % tag_name) + return "" + "\n".join(elements) + "" + +def benchmark_parsers(num_elements=100000): + """Very basic head-to-head performance benchmark.""" + print(("Comparative parser benchmark on Beautiful Soup %s" % __version__)) + data = rdoc(num_elements) + print(("Generated a large invalid HTML document (%d bytes)." % len(data))) + + for parser in ["lxml", ["lxml", "html"], "html5lib", "html.parser"]: + success = False + try: + a = time.time() + soup = BeautifulSoup(data, parser) + b = time.time() + success = True + except Exception as e: + print(("%s could not parse the markup." % parser)) + traceback.print_exc() + if success: + print(("BS4+%s parsed the markup in %.2fs." % (parser, b-a))) + + from lxml import etree + a = time.time() + etree.HTML(data) + b = time.time() + print(("Raw lxml parsed the markup in %.2fs." % (b-a))) + + import html5lib + parser = html5lib.HTMLParser() + a = time.time() + parser.parse(data) + b = time.time() + print(("Raw html5lib parsed the markup in %.2fs." % (b-a))) + +def profile(num_elements=100000, parser="lxml"): + """Use Python's profiler on a randomly generated document.""" + filehandle = tempfile.NamedTemporaryFile() + filename = filehandle.name + + data = rdoc(num_elements) + vars = dict(bs4=bs4, data=data, parser=parser) + cProfile.runctx('bs4.BeautifulSoup(data, parser)' , vars, vars, filename) + + stats = pstats.Stats(filename) + # stats.strip_dirs() + stats.sort_stats("cumulative") + stats.print_stats('_html5lib|bs4', 50) + +# If this file is run as a script, standard input is diagnosed. +if __name__ == '__main__': + diagnose(sys.stdin.read()) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/element.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/element.py new file mode 100644 index 00000000..82a986e4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/element.py @@ -0,0 +1,2255 @@ +# Use of this source code is governed by the MIT license. +__license__ = "MIT" + +try: + from collections.abc import Callable # Python 3.6 +except ImportError as e: + from collections import Callable +import re +import sys +import warnings +try: + import soupsieve +except ImportError as e: + soupsieve = None + warnings.warn( + 'The soupsieve package is not installed. CSS selectors cannot be used.' + ) + +from bs4.formatter import ( + Formatter, + HTMLFormatter, + XMLFormatter, +) + +DEFAULT_OUTPUT_ENCODING = "utf-8" +PY3K = (sys.version_info[0] > 2) + +nonwhitespace_re = re.compile(r"\S+") + +# NOTE: This isn't used as of 4.7.0. I'm leaving it for a little bit on +# the off chance someone imported it for their own use. +whitespace_re = re.compile(r"\s+") + +def _alias(attr): + """Alias one attribute name to another for backward compatibility""" + @property + def alias(self): + return getattr(self, attr) + + @alias.setter + def alias(self): + return setattr(self, attr) + return alias + + +# These encodings are recognized by Python (so PageElement.encode +# could theoretically support them) but XML and HTML don't recognize +# them (so they should not show up in an XML or HTML document as that +# document's encoding). +# +# If an XML document is encoded in one of these encodings, no encoding +# will be mentioned in the XML declaration. If an HTML document is +# encoded in one of these encodings, and the HTML document has a +# tag that mentions an encoding, the encoding will be given as +# the empty string. +# +# Source: +# https://docs.python.org/3/library/codecs.html#python-specific-encodings +PYTHON_SPECIFIC_ENCODINGS = set([ + "idna", + "mbcs", + "oem", + "palmos", + "punycode", + "raw_unicode_escape", + "undefined", + "unicode_escape", + "raw-unicode-escape", + "unicode-escape", + "string-escape", + "string_escape", +]) + + +class NamespacedAttribute(str): + """A namespaced string (e.g. 'xml:lang') that remembers the namespace + ('xml') and the name ('lang') that were used to create it. + """ + + def __new__(cls, prefix, name=None, namespace=None): + if not name: + # This is the default namespace. Its name "has no value" + # per https://www.w3.org/TR/xml-names/#defaulting + name = None + + if not name: + obj = str.__new__(cls, prefix) + elif not prefix: + # Not really namespaced. + obj = str.__new__(cls, name) + else: + obj = str.__new__(cls, prefix + ":" + name) + obj.prefix = prefix + obj.name = name + obj.namespace = namespace + return obj + +class AttributeValueWithCharsetSubstitution(str): + """A stand-in object for a character encoding specified in HTML.""" + +class CharsetMetaAttributeValue(AttributeValueWithCharsetSubstitution): + """A generic stand-in for the value of a meta tag's 'charset' attribute. + + When Beautiful Soup parses the markup '', the + value of the 'charset' attribute will be one of these objects. + """ + + def __new__(cls, original_value): + obj = str.__new__(cls, original_value) + obj.original_value = original_value + return obj + + def encode(self, encoding): + """When an HTML document is being encoded to a given encoding, the + value of a meta tag's 'charset' is the name of the encoding. + """ + if encoding in PYTHON_SPECIFIC_ENCODINGS: + return '' + return encoding + + +class ContentMetaAttributeValue(AttributeValueWithCharsetSubstitution): + """A generic stand-in for the value of a meta tag's 'content' attribute. + + When Beautiful Soup parses the markup: + + + The value of the 'content' attribute will be one of these objects. + """ + + CHARSET_RE = re.compile(r"((^|;)\s*charset=)([^;]*)", re.M) + + def __new__(cls, original_value): + match = cls.CHARSET_RE.search(original_value) + if match is None: + # No substitution necessary. + return str.__new__(str, original_value) + + obj = str.__new__(cls, original_value) + obj.original_value = original_value + return obj + + def encode(self, encoding): + if encoding in PYTHON_SPECIFIC_ENCODINGS: + return '' + def rewrite(match): + return match.group(1) + encoding + return self.CHARSET_RE.sub(rewrite, self.original_value) + + +class PageElement(object): + """Contains the navigational information for some part of the page: + that is, its current location in the parse tree. + + NavigableString, Tag, etc. are all subclasses of PageElement. + """ + + def setup(self, parent=None, previous_element=None, next_element=None, + previous_sibling=None, next_sibling=None): + """Sets up the initial relations between this element and + other elements. + + :param parent: The parent of this element. + + :param previous_element: The element parsed immediately before + this one. + + :param next_element: The element parsed immediately before + this one. + + :param previous_sibling: The most recently encountered element + on the same level of the parse tree as this one. + + :param previous_sibling: The next element to be encountered + on the same level of the parse tree as this one. + """ + self.parent = parent + + self.previous_element = previous_element + if previous_element is not None: + self.previous_element.next_element = self + + self.next_element = next_element + if self.next_element is not None: + self.next_element.previous_element = self + + self.next_sibling = next_sibling + if self.next_sibling is not None: + self.next_sibling.previous_sibling = self + + if (previous_sibling is None + and self.parent is not None and self.parent.contents): + previous_sibling = self.parent.contents[-1] + + self.previous_sibling = previous_sibling + if previous_sibling is not None: + self.previous_sibling.next_sibling = self + + def format_string(self, s, formatter): + """Format the given string using the given formatter. + + :param s: A string. + :param formatter: A Formatter object, or a string naming one of the standard formatters. + """ + if formatter is None: + return s + if not isinstance(formatter, Formatter): + formatter = self.formatter_for_name(formatter) + output = formatter.substitute(s) + return output + + def formatter_for_name(self, formatter): + """Look up or create a Formatter for the given identifier, + if necessary. + + :param formatter: Can be a Formatter object (used as-is), a + function (used as the entity substitution hook for an + XMLFormatter or HTMLFormatter), or a string (used to look + up an XMLFormatter or HTMLFormatter in the appropriate + registry. + """ + if isinstance(formatter, Formatter): + return formatter + if self._is_xml: + c = XMLFormatter + else: + c = HTMLFormatter + if isinstance(formatter, Callable): + return c(entity_substitution=formatter) + return c.REGISTRY[formatter] + + @property + def _is_xml(self): + """Is this element part of an XML tree or an HTML tree? + + This is used in formatter_for_name, when deciding whether an + XMLFormatter or HTMLFormatter is more appropriate. It can be + inefficient, but it should be called very rarely. + """ + if self.known_xml is not None: + # Most of the time we will have determined this when the + # document is parsed. + return self.known_xml + + # Otherwise, it's likely that this element was created by + # direct invocation of the constructor from within the user's + # Python code. + if self.parent is None: + # This is the top-level object. It should have .known_xml set + # from tree creation. If not, take a guess--BS is usually + # used on HTML markup. + return getattr(self, 'is_xml', False) + return self.parent._is_xml + + nextSibling = _alias("next_sibling") # BS3 + previousSibling = _alias("previous_sibling") # BS3 + + default = object() + def _all_strings(self, strip=False, types=default): + """Yield all strings of certain classes, possibly stripping them. + + This is implemented differently in Tag and NavigableString. + """ + raise NotImplementedError() + + @property + def stripped_strings(self): + """Yield all strings in this PageElement, stripping them first. + + :yield: A sequence of stripped strings. + """ + for string in self._all_strings(True): + yield string + + def get_text(self, separator="", strip=False, + types=default): + """Get all child strings of this PageElement, concatenated using the + given separator. + + :param separator: Strings will be concatenated using this separator. + + :param strip: If True, strings will be stripped before being + concatenated. + + :param types: A tuple of NavigableString subclasses. Any + strings of a subclass not found in this list will be + ignored. Although there are exceptions, the default + behavior in most cases is to consider only NavigableString + and CData objects. That means no comments, processing + instructions, etc. + + :return: A string. + """ + return separator.join([s for s in self._all_strings( + strip, types=types)]) + getText = get_text + text = property(get_text) + + def replace_with(self, *args): + """Replace this PageElement with one or more PageElements, keeping the + rest of the tree the same. + + :param args: One or more PageElements. + :return: `self`, no longer part of the tree. + """ + if self.parent is None: + raise ValueError( + "Cannot replace one element with another when the " + "element to be replaced is not part of a tree.") + if len(args) == 1 and args[0] is self: + return + if any(x is self.parent for x in args): + raise ValueError("Cannot replace a Tag with its parent.") + old_parent = self.parent + my_index = self.parent.index(self) + self.extract(_self_index=my_index) + for idx, replace_with in enumerate(args, start=my_index): + old_parent.insert(idx, replace_with) + return self + replaceWith = replace_with # BS3 + + def unwrap(self): + """Replace this PageElement with its contents. + + :return: `self`, no longer part of the tree. + """ + my_parent = self.parent + if self.parent is None: + raise ValueError( + "Cannot replace an element with its contents when that" + "element is not part of a tree.") + my_index = self.parent.index(self) + self.extract(_self_index=my_index) + for child in reversed(self.contents[:]): + my_parent.insert(my_index, child) + return self + replace_with_children = unwrap + replaceWithChildren = unwrap # BS3 + + def wrap(self, wrap_inside): + """Wrap this PageElement inside another one. + + :param wrap_inside: A PageElement. + :return: `wrap_inside`, occupying the position in the tree that used + to be occupied by `self`, and with `self` inside it. + """ + me = self.replace_with(wrap_inside) + wrap_inside.append(me) + return wrap_inside + + def extract(self, _self_index=None): + """Destructively rips this element out of the tree. + + :param _self_index: The location of this element in its parent's + .contents, if known. Passing this in allows for a performance + optimization. + + :return: `self`, no longer part of the tree. + """ + if self.parent is not None: + if _self_index is None: + _self_index = self.parent.index(self) + del self.parent.contents[_self_index] + + #Find the two elements that would be next to each other if + #this element (and any children) hadn't been parsed. Connect + #the two. + last_child = self._last_descendant() + next_element = last_child.next_element + + if (self.previous_element is not None and + self.previous_element is not next_element): + self.previous_element.next_element = next_element + if next_element is not None and next_element is not self.previous_element: + next_element.previous_element = self.previous_element + self.previous_element = None + last_child.next_element = None + + self.parent = None + if (self.previous_sibling is not None + and self.previous_sibling is not self.next_sibling): + self.previous_sibling.next_sibling = self.next_sibling + if (self.next_sibling is not None + and self.next_sibling is not self.previous_sibling): + self.next_sibling.previous_sibling = self.previous_sibling + self.previous_sibling = self.next_sibling = None + return self + + def _last_descendant(self, is_initialized=True, accept_self=True): + """Finds the last element beneath this object to be parsed. + + :param is_initialized: Has `setup` been called on this PageElement + yet? + :param accept_self: Is `self` an acceptable answer to the question? + """ + if is_initialized and self.next_sibling is not None: + last_child = self.next_sibling.previous_element + else: + last_child = self + while isinstance(last_child, Tag) and last_child.contents: + last_child = last_child.contents[-1] + if not accept_self and last_child is self: + last_child = None + return last_child + # BS3: Not part of the API! + _lastRecursiveChild = _last_descendant + + def insert(self, position, new_child): + """Insert a new PageElement in the list of this PageElement's children. + + This works the same way as `list.insert`. + + :param position: The numeric position that should be occupied + in `self.children` by the new PageElement. + :param new_child: A PageElement. + """ + if new_child is None: + raise ValueError("Cannot insert None into a tag.") + if new_child is self: + raise ValueError("Cannot insert a tag into itself.") + if (isinstance(new_child, str) + and not isinstance(new_child, NavigableString)): + new_child = NavigableString(new_child) + + from bs4 import BeautifulSoup + if isinstance(new_child, BeautifulSoup): + # We don't want to end up with a situation where one BeautifulSoup + # object contains another. Insert the children one at a time. + for subchild in list(new_child.contents): + self.insert(position, subchild) + position += 1 + return + position = min(position, len(self.contents)) + if hasattr(new_child, 'parent') and new_child.parent is not None: + # We're 'inserting' an element that's already one + # of this object's children. + if new_child.parent is self: + current_index = self.index(new_child) + if current_index < position: + # We're moving this element further down the list + # of this object's children. That means that when + # we extract this element, our target index will + # jump down one. + position -= 1 + new_child.extract() + + new_child.parent = self + previous_child = None + if position == 0: + new_child.previous_sibling = None + new_child.previous_element = self + else: + previous_child = self.contents[position - 1] + new_child.previous_sibling = previous_child + new_child.previous_sibling.next_sibling = new_child + new_child.previous_element = previous_child._last_descendant(False) + if new_child.previous_element is not None: + new_child.previous_element.next_element = new_child + + new_childs_last_element = new_child._last_descendant(False) + + if position >= len(self.contents): + new_child.next_sibling = None + + parent = self + parents_next_sibling = None + while parents_next_sibling is None and parent is not None: + parents_next_sibling = parent.next_sibling + parent = parent.parent + if parents_next_sibling is not None: + # We found the element that comes next in the document. + break + if parents_next_sibling is not None: + new_childs_last_element.next_element = parents_next_sibling + else: + # The last element of this tag is the last element in + # the document. + new_childs_last_element.next_element = None + else: + next_child = self.contents[position] + new_child.next_sibling = next_child + if new_child.next_sibling is not None: + new_child.next_sibling.previous_sibling = new_child + new_childs_last_element.next_element = next_child + + if new_childs_last_element.next_element is not None: + new_childs_last_element.next_element.previous_element = new_childs_last_element + self.contents.insert(position, new_child) + + def append(self, tag): + """Appends the given PageElement to the contents of this one. + + :param tag: A PageElement. + """ + self.insert(len(self.contents), tag) + + def extend(self, tags): + """Appends the given PageElements to this one's contents. + + :param tags: A list of PageElements. + """ + if isinstance(tags, Tag): + # Calling self.append() on another tag's contents will change + # the list we're iterating over. Make a list that won't + # change. + tags = list(tags.contents) + for tag in tags: + self.append(tag) + + def insert_before(self, *args): + """Makes the given element(s) the immediate predecessor of this one. + + All the elements will have the same parent, and the given elements + will be immediately before this one. + + :param args: One or more PageElements. + """ + parent = self.parent + if parent is None: + raise ValueError( + "Element has no parent, so 'before' has no meaning.") + if any(x is self for x in args): + raise ValueError("Can't insert an element before itself.") + for predecessor in args: + # Extract first so that the index won't be screwed up if they + # are siblings. + if isinstance(predecessor, PageElement): + predecessor.extract() + index = parent.index(self) + parent.insert(index, predecessor) + + def insert_after(self, *args): + """Makes the given element(s) the immediate successor of this one. + + The elements will have the same parent, and the given elements + will be immediately after this one. + + :param args: One or more PageElements. + """ + # Do all error checking before modifying the tree. + parent = self.parent + if parent is None: + raise ValueError( + "Element has no parent, so 'after' has no meaning.") + if any(x is self for x in args): + raise ValueError("Can't insert an element after itself.") + + offset = 0 + for successor in args: + # Extract first so that the index won't be screwed up if they + # are siblings. + if isinstance(successor, PageElement): + successor.extract() + index = parent.index(self) + parent.insert(index+1+offset, successor) + offset += 1 + + def find_next(self, name=None, attrs={}, text=None, **kwargs): + """Find the first PageElement that matches the given criteria and + appears later in the document than this PageElement. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :kwargs: A dictionary of filters on attribute values. + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self._find_one(self.find_all_next, name, attrs, text, **kwargs) + findNext = find_next # BS3 + + def find_all_next(self, name=None, attrs={}, text=None, limit=None, + **kwargs): + """Find all PageElements that match the given criteria and appear + later in the document than this PageElement. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :param limit: Stop looking after finding this many results. + :kwargs: A dictionary of filters on attribute values. + :return: A ResultSet containing PageElements. + """ + return self._find_all(name, attrs, text, limit, self.next_elements, + **kwargs) + findAllNext = find_all_next # BS3 + + def find_next_sibling(self, name=None, attrs={}, text=None, **kwargs): + """Find the closest sibling to this PageElement that matches the + given criteria and appears later in the document. + + All find_* methods take a common set of arguments. See the + online documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :kwargs: A dictionary of filters on attribute values. + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self._find_one(self.find_next_siblings, name, attrs, text, + **kwargs) + findNextSibling = find_next_sibling # BS3 + + def find_next_siblings(self, name=None, attrs={}, text=None, limit=None, + **kwargs): + """Find all siblings of this PageElement that match the given criteria + and appear later in the document. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :param limit: Stop looking after finding this many results. + :kwargs: A dictionary of filters on attribute values. + :return: A ResultSet of PageElements. + :rtype: bs4.element.ResultSet + """ + return self._find_all(name, attrs, text, limit, + self.next_siblings, **kwargs) + findNextSiblings = find_next_siblings # BS3 + fetchNextSiblings = find_next_siblings # BS2 + + def find_previous(self, name=None, attrs={}, text=None, **kwargs): + """Look backwards in the document from this PageElement and find the + first PageElement that matches the given criteria. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :kwargs: A dictionary of filters on attribute values. + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self._find_one( + self.find_all_previous, name, attrs, text, **kwargs) + findPrevious = find_previous # BS3 + + def find_all_previous(self, name=None, attrs={}, text=None, limit=None, + **kwargs): + """Look backwards in the document from this PageElement and find all + PageElements that match the given criteria. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :param limit: Stop looking after finding this many results. + :kwargs: A dictionary of filters on attribute values. + :return: A ResultSet of PageElements. + :rtype: bs4.element.ResultSet + """ + return self._find_all(name, attrs, text, limit, self.previous_elements, + **kwargs) + findAllPrevious = find_all_previous # BS3 + fetchPrevious = find_all_previous # BS2 + + def find_previous_sibling(self, name=None, attrs={}, text=None, **kwargs): + """Returns the closest sibling to this PageElement that matches the + given criteria and appears earlier in the document. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :kwargs: A dictionary of filters on attribute values. + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self._find_one(self.find_previous_siblings, name, attrs, text, + **kwargs) + findPreviousSibling = find_previous_sibling # BS3 + + def find_previous_siblings(self, name=None, attrs={}, text=None, + limit=None, **kwargs): + """Returns all siblings to this PageElement that match the + given criteria and appear earlier in the document. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param text: A filter for a NavigableString with specific text. + :param limit: Stop looking after finding this many results. + :kwargs: A dictionary of filters on attribute values. + :return: A ResultSet of PageElements. + :rtype: bs4.element.ResultSet + """ + return self._find_all(name, attrs, text, limit, + self.previous_siblings, **kwargs) + findPreviousSiblings = find_previous_siblings # BS3 + fetchPreviousSiblings = find_previous_siblings # BS2 + + def find_parent(self, name=None, attrs={}, **kwargs): + """Find the closest parent of this PageElement that matches the given + criteria. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :kwargs: A dictionary of filters on attribute values. + + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + # NOTE: We can't use _find_one because findParents takes a different + # set of arguments. + r = None + l = self.find_parents(name, attrs, 1, **kwargs) + if l: + r = l[0] + return r + findParent = find_parent # BS3 + + def find_parents(self, name=None, attrs={}, limit=None, **kwargs): + """Find all parents of this PageElement that match the given criteria. + + All find_* methods take a common set of arguments. See the online + documentation for detailed explanations. + + :param name: A filter on tag name. + :param attrs: A dictionary of filters on attribute values. + :param limit: Stop looking after finding this many results. + :kwargs: A dictionary of filters on attribute values. + + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self._find_all(name, attrs, None, limit, self.parents, + **kwargs) + findParents = find_parents # BS3 + fetchParents = find_parents # BS2 + + @property + def next(self): + """The PageElement, if any, that was parsed just after this one. + + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self.next_element + + @property + def previous(self): + """The PageElement, if any, that was parsed just before this one. + + :return: A PageElement. + :rtype: bs4.element.Tag | bs4.element.NavigableString + """ + return self.previous_element + + #These methods do the real heavy lifting. + + def _find_one(self, method, name, attrs, text, **kwargs): + r = None + l = method(name, attrs, text, 1, **kwargs) + if l: + r = l[0] + return r + + def _find_all(self, name, attrs, text, limit, generator, **kwargs): + "Iterates over a generator looking for things that match." + + if text is None and 'string' in kwargs: + text = kwargs['string'] + del kwargs['string'] + + if isinstance(name, SoupStrainer): + strainer = name + else: + strainer = SoupStrainer(name, attrs, text, **kwargs) + + if text is None and not limit and not attrs and not kwargs: + if name is True or name is None: + # Optimization to find all tags. + result = (element for element in generator + if isinstance(element, Tag)) + return ResultSet(strainer, result) + elif isinstance(name, str): + # Optimization to find all tags with a given name. + if name.count(':') == 1: + # This is a name with a prefix. If this is a namespace-aware document, + # we need to match the local name against tag.name. If not, + # we need to match the fully-qualified name against tag.name. + prefix, local_name = name.split(':', 1) + else: + prefix = None + local_name = name + result = (element for element in generator + if isinstance(element, Tag) + and ( + element.name == name + ) or ( + element.name == local_name + and (prefix is None or element.prefix == prefix) + ) + ) + return ResultSet(strainer, result) + results = ResultSet(strainer) + while True: + try: + i = next(generator) + except StopIteration: + break + if i: + found = strainer.search(i) + if found: + results.append(found) + if limit and len(results) >= limit: + break + return results + + #These generators can be used to navigate starting from both + #NavigableStrings and Tags. + @property + def next_elements(self): + """All PageElements that were parsed after this one. + + :yield: A sequence of PageElements. + """ + i = self.next_element + while i is not None: + yield i + i = i.next_element + + @property + def next_siblings(self): + """All PageElements that are siblings of this one but were parsed + later. + + :yield: A sequence of PageElements. + """ + i = self.next_sibling + while i is not None: + yield i + i = i.next_sibling + + @property + def previous_elements(self): + """All PageElements that were parsed before this one. + + :yield: A sequence of PageElements. + """ + i = self.previous_element + while i is not None: + yield i + i = i.previous_element + + @property + def previous_siblings(self): + """All PageElements that are siblings of this one but were parsed + earlier. + + :yield: A sequence of PageElements. + """ + i = self.previous_sibling + while i is not None: + yield i + i = i.previous_sibling + + @property + def parents(self): + """All PageElements that are parents of this PageElement. + + :yield: A sequence of PageElements. + """ + i = self.parent + while i is not None: + yield i + i = i.parent + + @property + def decomposed(self): + """Check whether a PageElement has been decomposed. + + :rtype: bool + """ + return getattr(self, '_decomposed', False) or False + + # Old non-property versions of the generators, for backwards + # compatibility with BS3. + def nextGenerator(self): + return self.next_elements + + def nextSiblingGenerator(self): + return self.next_siblings + + def previousGenerator(self): + return self.previous_elements + + def previousSiblingGenerator(self): + return self.previous_siblings + + def parentGenerator(self): + return self.parents + + +class NavigableString(str, PageElement): + """A Python Unicode string that is part of a parse tree. + + When Beautiful Soup parses the markup penguin, it will + create a NavigableString for the string "penguin". + """ + + PREFIX = '' + SUFFIX = '' + + # We can't tell just by looking at a string whether it's contained + # in an XML document or an HTML document. + + known_xml = None + + def __new__(cls, value): + """Create a new NavigableString. + + When unpickling a NavigableString, this method is called with + the string in DEFAULT_OUTPUT_ENCODING. That encoding needs to be + passed in to the superclass's __new__ or the superclass won't know + how to handle non-ASCII characters. + """ + if isinstance(value, str): + u = str.__new__(cls, value) + else: + u = str.__new__(cls, value, DEFAULT_OUTPUT_ENCODING) + u.setup() + return u + + def __copy__(self): + """A copy of a NavigableString has the same contents and class + as the original, but it is not connected to the parse tree. + """ + return type(self)(self) + + def __getnewargs__(self): + return (str(self),) + + def __getattr__(self, attr): + """text.string gives you text. This is for backwards + compatibility for Navigable*String, but for CData* it lets you + get the string without the CData wrapper.""" + if attr == 'string': + return self + else: + raise AttributeError( + "'%s' object has no attribute '%s'" % ( + self.__class__.__name__, attr)) + + def output_ready(self, formatter="minimal"): + """Run the string through the provided formatter. + + :param formatter: A Formatter object, or a string naming one of the standard formatters. + """ + output = self.format_string(self, formatter) + return self.PREFIX + output + self.SUFFIX + + @property + def name(self): + """Since a NavigableString is not a Tag, it has no .name. + + This property is implemented so that code like this doesn't crash + when run on a mixture of Tag and NavigableString objects: + [x.name for x in tag.children] + """ + return None + + @name.setter + def name(self, name): + """Prevent NavigableString.name from ever being set.""" + raise AttributeError("A NavigableString cannot be given a name.") + + def _all_strings(self, strip=False, types=PageElement.default): + """Yield all strings of certain classes, possibly stripping them. + + This makes it easy for NavigableString to implement methods + like get_text() as conveniences, creating a consistent + text-extraction API across all PageElements. + + :param strip: If True, all strings will be stripped before being + yielded. + + :param types: A tuple of NavigableString subclasses. If this + NavigableString isn't one of those subclasses, the + sequence will be empty. By default, the subclasses + considered are NavigableString and CData objects. That + means no comments, processing instructions, etc. + + :yield: A sequence that either contains this string, or is empty. + + """ + if types is self.default: + # This is kept in Tag because it's full of subclasses of + # this class, which aren't defined until later in the file. + types = Tag.DEFAULT_INTERESTING_STRING_TYPES + + # Do nothing if the caller is looking for specific types of + # string, and we're of a different type. + my_type = type(self) + if types is not None: + if isinstance(types, type): + # Looking for a single type. + if my_type is not types: + return + elif my_type not in types: + # Looking for one of a list of types. + return + + value = self + if strip: + value = value.strip() + if len(value) > 0: + yield value + strings = property(_all_strings) + +class PreformattedString(NavigableString): + """A NavigableString not subject to the normal formatting rules. + + This is an abstract class used for special kinds of strings such + as comments (the Comment class) and CDATA blocks (the CData + class). + """ + + PREFIX = '' + SUFFIX = '' + + def output_ready(self, formatter=None): + """Make this string ready for output by adding any subclass-specific + prefix or suffix. + + :param formatter: A Formatter object, or a string naming one + of the standard formatters. The string will be passed into the + Formatter, but only to trigger any side effects: the return + value is ignored. + + :return: The string, with any subclass-specific prefix and + suffix added on. + """ + if formatter is not None: + ignore = self.format_string(self, formatter) + return self.PREFIX + self + self.SUFFIX + +class CData(PreformattedString): + """A CDATA block.""" + PREFIX = '' + +class ProcessingInstruction(PreformattedString): + """A SGML processing instruction.""" + + PREFIX = '' + +class XMLProcessingInstruction(ProcessingInstruction): + """An XML processing instruction.""" + PREFIX = '' + +class Comment(PreformattedString): + """An HTML or XML comment.""" + PREFIX = '' + + +class Declaration(PreformattedString): + """An XML declaration.""" + PREFIX = '' + + +class Doctype(PreformattedString): + """A document type declaration.""" + @classmethod + def for_name_and_ids(cls, name, pub_id, system_id): + """Generate an appropriate document type declaration for a given + public ID and system ID. + + :param name: The name of the document's root element, e.g. 'html'. + :param pub_id: The Formal Public Identifier for this document type, + e.g. '-//W3C//DTD XHTML 1.1//EN' + :param system_id: The system identifier for this document type, + e.g. 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd' + + :return: A Doctype. + """ + value = name or '' + if pub_id is not None: + value += ' PUBLIC "%s"' % pub_id + if system_id is not None: + value += ' "%s"' % system_id + elif system_id is not None: + value += ' SYSTEM "%s"' % system_id + + return Doctype(value) + + PREFIX = '\n' + + +class Stylesheet(NavigableString): + """A NavigableString representing an stylesheet (probably + CSS). + + Used to distinguish embedded stylesheets from textual content. + """ + pass + + +class Script(NavigableString): + """A NavigableString representing an executable script (probably + Javascript). + + Used to distinguish executable code from textual content. + """ + pass + + +class TemplateString(NavigableString): + """A NavigableString representing a string found inside an HTML + template embedded in a larger document. + + Used to distinguish such strings from the main body of the document. + """ + pass + + +class Tag(PageElement): + """Represents an HTML or XML tag that is part of a parse tree, along + with its attributes and contents. + + When Beautiful Soup parses the markup penguin, it will + create a Tag object representing the tag. + """ + + def __init__(self, parser=None, builder=None, name=None, namespace=None, + prefix=None, attrs=None, parent=None, previous=None, + is_xml=None, sourceline=None, sourcepos=None, + can_be_empty_element=None, cdata_list_attributes=None, + preserve_whitespace_tags=None, + interesting_string_types=None, + ): + """Basic constructor. + + :param parser: A BeautifulSoup object. + :param builder: A TreeBuilder. + :param name: The name of the tag. + :param namespace: The URI of this Tag's XML namespace, if any. + :param prefix: The prefix for this Tag's XML namespace, if any. + :param attrs: A dictionary of this Tag's attribute values. + :param parent: The PageElement to use as this Tag's parent. + :param previous: The PageElement that was parsed immediately before + this tag. + :param is_xml: If True, this is an XML tag. Otherwise, this is an + HTML tag. + :param sourceline: The line number where this tag was found in its + source document. + :param sourcepos: The character position within `sourceline` where this + tag was found. + :param can_be_empty_element: If True, this tag should be + represented as . If False, this tag should be represented + as . + :param cdata_list_attributes: A list of attributes whose values should + be treated as CDATA if they ever show up on this tag. + :param preserve_whitespace_tags: A list of tag names whose contents + should have their whitespace preserved. + :param interesting_string_types: This is a NavigableString + subclass or a tuple of them. When iterating over this + Tag's strings in methods like Tag.strings or Tag.get_text, + these are the types of strings that are interesting enough + to be considered. The default is to consider + NavigableString and CData the only interesting string + subtypes. + """ + if parser is None: + self.parser_class = None + else: + # We don't actually store the parser object: that lets extracted + # chunks be garbage-collected. + self.parser_class = parser.__class__ + if name is None: + raise ValueError("No value provided for new tag's name.") + self.name = name + self.namespace = namespace + self.prefix = prefix + if ((not builder or builder.store_line_numbers) + and (sourceline is not None or sourcepos is not None)): + self.sourceline = sourceline + self.sourcepos = sourcepos + if attrs is None: + attrs = {} + elif attrs: + if builder is not None and builder.cdata_list_attributes: + attrs = builder._replace_cdata_list_attribute_values( + self.name, attrs) + else: + attrs = dict(attrs) + else: + attrs = dict(attrs) + + # If possible, determine ahead of time whether this tag is an + # XML tag. + if builder: + self.known_xml = builder.is_xml + else: + self.known_xml = is_xml + self.attrs = attrs + self.contents = [] + self.setup(parent, previous) + self.hidden = False + + if builder is None: + # In the absence of a TreeBuilder, use whatever values were + # passed in here. They're probably None, unless this is a copy of some + # other tag. + self.can_be_empty_element = can_be_empty_element + self.cdata_list_attributes = cdata_list_attributes + self.preserve_whitespace_tags = preserve_whitespace_tags + self.interesting_string_types = interesting_string_types + else: + # Set up any substitutions for this tag, such as the charset in a META tag. + builder.set_up_substitutions(self) + + # Ask the TreeBuilder whether this tag might be an empty-element tag. + self.can_be_empty_element = builder.can_be_empty_element(name) + + # Keep track of the list of attributes of this tag that + # might need to be treated as a list. + # + # For performance reasons, we store the whole data structure + # rather than asking the question of every tag. Asking would + # require building a new data structure every time, and + # (unlike can_be_empty_element), we almost never need + # to check this. + self.cdata_list_attributes = builder.cdata_list_attributes + + # Keep track of the names that might cause this tag to be treated as a + # whitespace-preserved tag. + self.preserve_whitespace_tags = builder.preserve_whitespace_tags + + if self.name in builder.string_containers: + # This sort of tag uses a special string container + # subclass for most of its strings. When we ask the + self.interesting_string_types = builder.string_containers[self.name] + else: + self.interesting_string_types = self.DEFAULT_INTERESTING_STRING_TYPES + + parserClass = _alias("parser_class") # BS3 + + def __copy__(self): + """A copy of a Tag is a new Tag, unconnected to the parse tree. + Its contents are a copy of the old Tag's contents. + """ + clone = type(self)( + None, self.builder, self.name, self.namespace, + self.prefix, self.attrs, is_xml=self._is_xml, + sourceline=self.sourceline, sourcepos=self.sourcepos, + can_be_empty_element=self.can_be_empty_element, + cdata_list_attributes=self.cdata_list_attributes, + preserve_whitespace_tags=self.preserve_whitespace_tags + ) + for attr in ('can_be_empty_element', 'hidden'): + setattr(clone, attr, getattr(self, attr)) + for child in self.contents: + clone.append(child.__copy__()) + return clone + + @property + def is_empty_element(self): + """Is this tag an empty-element tag? (aka a self-closing tag) + + A tag that has contents is never an empty-element tag. + + A tag that has no contents may or may not be an empty-element + tag. It depends on the builder used to create the tag. If the + builder has a designated list of empty-element tags, then only + a tag whose name shows up in that list is considered an + empty-element tag. + + If the builder has no designated list of empty-element tags, + then any tag with no contents is an empty-element tag. + """ + return len(self.contents) == 0 and self.can_be_empty_element + isSelfClosing = is_empty_element # BS3 + + @property + def string(self): + """Convenience property to get the single string within this + PageElement. + + TODO It might make sense to have NavigableString.string return + itself. + + :return: If this element has a single string child, return + value is that string. If this element has one child tag, + return value is the 'string' attribute of the child tag, + recursively. If this element is itself a string, has no + children, or has more than one child, return value is None. + """ + if len(self.contents) != 1: + return None + child = self.contents[0] + if isinstance(child, NavigableString): + return child + return child.string + + @string.setter + def string(self, string): + """Replace this PageElement's contents with `string`.""" + self.clear() + self.append(string.__class__(string)) + + DEFAULT_INTERESTING_STRING_TYPES = (NavigableString, CData) + def _all_strings(self, strip=False, types=PageElement.default): + """Yield all strings of certain classes, possibly stripping them. + + :param strip: If True, all strings will be stripped before being + yielded. + + :param types: A tuple of NavigableString subclasses. Any strings of + a subclass not found in this list will be ignored. By + default, the subclasses considered are the ones found in + self.interesting_string_types. If that's not specified, + only NavigableString and CData objects will be + considered. That means no comments, processing + instructions, etc. + + :yield: A sequence of strings. + + """ + if types is self.default: + types = self.interesting_string_types + + for descendant in self.descendants: + if (types is None and not isinstance(descendant, NavigableString)): + continue + descendant_type = type(descendant) + if isinstance(types, type): + if descendant_type is not types: + # We're not interested in strings of this type. + continue + elif types is not None and descendant_type not in types: + # We're not interested in strings of this type. + continue + if strip: + descendant = descendant.strip() + if len(descendant) == 0: + continue + yield descendant + strings = property(_all_strings) + + def decompose(self): + """Recursively destroys this PageElement and its children. + + This element will be removed from the tree and wiped out; so + will everything beneath it. + + The behavior of a decomposed PageElement is undefined and you + should never use one for anything, but if you need to _check_ + whether an element has been decomposed, you can use the + `decomposed` property. + """ + self.extract() + i = self + while i is not None: + n = i.next_element + i.__dict__.clear() + i.contents = [] + i._decomposed = True + i = n + + def clear(self, decompose=False): + """Wipe out all children of this PageElement by calling extract() + on them. + + :param decompose: If this is True, decompose() (a more + destructive method) will be called instead of extract(). + """ + if decompose: + for element in self.contents[:]: + if isinstance(element, Tag): + element.decompose() + else: + element.extract() + else: + for element in self.contents[:]: + element.extract() + + def smooth(self): + """Smooth out this element's children by consolidating consecutive + strings. + + This makes pretty-printed output look more natural following a + lot of operations that modified the tree. + """ + # Mark the first position of every pair of children that need + # to be consolidated. Do this rather than making a copy of + # self.contents, since in most cases very few strings will be + # affected. + marked = [] + for i, a in enumerate(self.contents): + if isinstance(a, Tag): + # Recursively smooth children. + a.smooth() + if i == len(self.contents)-1: + # This is the last item in .contents, and it's not a + # tag. There's no chance it needs any work. + continue + b = self.contents[i+1] + if (isinstance(a, NavigableString) + and isinstance(b, NavigableString) + and not isinstance(a, PreformattedString) + and not isinstance(b, PreformattedString) + ): + marked.append(i) + + # Go over the marked positions in reverse order, so that + # removing items from .contents won't affect the remaining + # positions. + for i in reversed(marked): + a = self.contents[i] + b = self.contents[i+1] + b.extract() + n = NavigableString(a+b) + a.replace_with(n) + + def index(self, element): + """Find the index of a child by identity, not value. + + Avoids issues with tag.contents.index(element) getting the + index of equal elements. + + :param element: Look for this PageElement in `self.contents`. + """ + for i, child in enumerate(self.contents): + if child is element: + return i + raise ValueError("Tag.index: element not in tag") + + def get(self, key, default=None): + """Returns the value of the 'key' attribute for the tag, or + the value given for 'default' if it doesn't have that + attribute.""" + return self.attrs.get(key, default) + + def get_attribute_list(self, key, default=None): + """The same as get(), but always returns a list. + + :param key: The attribute to look for. + :param default: Use this value if the attribute is not present + on this PageElement. + :return: A list of values, probably containing only a single + value. + """ + value = self.get(key, default) + if not isinstance(value, list): + value = [value] + return value + + def has_attr(self, key): + """Does this PageElement have an attribute with the given name?""" + return key in self.attrs + + def __hash__(self): + return str(self).__hash__() + + def __getitem__(self, key): + """tag[key] returns the value of the 'key' attribute for the Tag, + and throws an exception if it's not there.""" + return self.attrs[key] + + def __iter__(self): + "Iterating over a Tag iterates over its contents." + return iter(self.contents) + + def __len__(self): + "The length of a Tag is the length of its list of contents." + return len(self.contents) + + def __contains__(self, x): + return x in self.contents + + def __bool__(self): + "A tag is non-None even if it has no contents." + return True + + def __setitem__(self, key, value): + """Setting tag[key] sets the value of the 'key' attribute for the + tag.""" + self.attrs[key] = value + + def __delitem__(self, key): + "Deleting tag[key] deletes all 'key' attributes for the tag." + self.attrs.pop(key, None) + + def __call__(self, *args, **kwargs): + """Calling a Tag like a function is the same as calling its + find_all() method. Eg. tag('a') returns a list of all the A tags + found within this tag.""" + return self.find_all(*args, **kwargs) + + def __getattr__(self, tag): + """Calling tag.subtag is the same as calling tag.find(name="subtag")""" + #print("Getattr %s.%s" % (self.__class__, tag)) + if len(tag) > 3 and tag.endswith('Tag'): + # BS3: soup.aTag -> "soup.find("a") + tag_name = tag[:-3] + warnings.warn( + '.%(name)sTag is deprecated, use .find("%(name)s") instead. If you really were looking for a tag called %(name)sTag, use .find("%(name)sTag")' % dict( + name=tag_name + ) + ) + return self.find(tag_name) + # We special case contents to avoid recursion. + elif not tag.startswith("__") and not tag == "contents": + return self.find(tag) + raise AttributeError( + "'%s' object has no attribute '%s'" % (self.__class__, tag)) + + def __eq__(self, other): + """Returns true iff this Tag has the same name, the same attributes, + and the same contents (recursively) as `other`.""" + if self is other: + return True + if (not hasattr(other, 'name') or + not hasattr(other, 'attrs') or + not hasattr(other, 'contents') or + self.name != other.name or + self.attrs != other.attrs or + len(self) != len(other)): + return False + for i, my_child in enumerate(self.contents): + if my_child != other.contents[i]: + return False + return True + + def __ne__(self, other): + """Returns true iff this Tag is not identical to `other`, + as defined in __eq__.""" + return not self == other + + def __repr__(self, encoding="unicode-escape"): + """Renders this PageElement as a string. + + :param encoding: The encoding to use (Python 2 only). + :return: Under Python 2, a bytestring; under Python 3, + a Unicode string. + """ + if PY3K: + # "The return value must be a string object", i.e. Unicode + return self.decode() + else: + # "The return value must be a string object", i.e. a bytestring. + # By convention, the return value of __repr__ should also be + # an ASCII string. + return self.encode(encoding) + + def __unicode__(self): + """Renders this PageElement as a Unicode string.""" + return self.decode() + + def __str__(self): + """Renders this PageElement as a generic string. + + :return: Under Python 2, a UTF-8 bytestring; under Python 3, + a Unicode string. + """ + if PY3K: + return self.decode() + else: + return self.encode() + + if PY3K: + __str__ = __repr__ = __unicode__ + + def encode(self, encoding=DEFAULT_OUTPUT_ENCODING, + indent_level=None, formatter="minimal", + errors="xmlcharrefreplace"): + """Render a bytestring representation of this PageElement and its + contents. + + :param encoding: The destination encoding. + :param indent_level: Each line of the rendering will be + indented this many spaces. Used internally in + recursive calls while pretty-printing. + :param formatter: A Formatter object, or a string naming one of + the standard formatters. + :param errors: An error handling strategy such as + 'xmlcharrefreplace'. This value is passed along into + encode() and its value should be one of the constants + defined by Python. + :return: A bytestring. + + """ + # Turn the data structure into Unicode, then encode the + # Unicode. + u = self.decode(indent_level, encoding, formatter) + return u.encode(encoding, errors) + + def decode(self, indent_level=None, + eventual_encoding=DEFAULT_OUTPUT_ENCODING, + formatter="minimal"): + """Render a Unicode representation of this PageElement and its + contents. + + :param indent_level: Each line of the rendering will be + indented this many spaces. Used internally in + recursive calls while pretty-printing. + :param eventual_encoding: The tag is destined to be + encoded into this encoding. This method is _not_ + responsible for performing that encoding. This information + is passed in so that it can be substituted in if the + document contains a tag that mentions the document's + encoding. + :param formatter: A Formatter object, or a string naming one of + the standard formatters. + """ + + # First off, turn a non-Formatter `formatter` into a Formatter + # object. This will stop the lookup from happening over and + # over again. + if not isinstance(formatter, Formatter): + formatter = self.formatter_for_name(formatter) + attributes = formatter.attributes(self) + attrs = [] + for key, val in attributes: + if val is None: + decoded = key + else: + if isinstance(val, list) or isinstance(val, tuple): + val = ' '.join(val) + elif not isinstance(val, str): + val = str(val) + elif ( + isinstance(val, AttributeValueWithCharsetSubstitution) + and eventual_encoding is not None + ): + val = val.encode(eventual_encoding) + + text = formatter.attribute_value(val) + decoded = ( + str(key) + '=' + + formatter.quoted_attribute_value(text)) + attrs.append(decoded) + close = '' + closeTag = '' + + prefix = '' + if self.prefix: + prefix = self.prefix + ":" + + if self.is_empty_element: + close = formatter.void_element_close_prefix or '' + else: + closeTag = '' % (prefix, self.name) + + pretty_print = self._should_pretty_print(indent_level) + space = '' + indent_space = '' + if indent_level is not None: + indent_space = (' ' * (indent_level - 1)) + if pretty_print: + space = indent_space + indent_contents = indent_level + 1 + else: + indent_contents = None + contents = self.decode_contents( + indent_contents, eventual_encoding, formatter + ) + + if self.hidden: + # This is the 'document root' object. + s = contents + else: + s = [] + attribute_string = '' + if attrs: + attribute_string = ' ' + ' '.join(attrs) + if indent_level is not None: + # Even if this particular tag is not pretty-printed, + # we should indent up to the start of the tag. + s.append(indent_space) + s.append('<%s%s%s%s>' % ( + prefix, self.name, attribute_string, close)) + if pretty_print: + s.append("\n") + s.append(contents) + if pretty_print and contents and contents[-1] != "\n": + s.append("\n") + if pretty_print and closeTag: + s.append(space) + s.append(closeTag) + if indent_level is not None and closeTag and self.next_sibling: + # Even if this particular tag is not pretty-printed, + # we're now done with the tag, and we should add a + # newline if appropriate. + s.append("\n") + s = ''.join(s) + return s + + def _should_pretty_print(self, indent_level): + """Should this tag be pretty-printed? + + Most of them should, but some (such as
 in HTML
+        documents) should not.
+        """
+        return (
+            indent_level is not None
+            and (
+                not self.preserve_whitespace_tags
+                or self.name not in self.preserve_whitespace_tags
+            )
+        )
+
+    def prettify(self, encoding=None, formatter="minimal"):
+        """Pretty-print this PageElement as a string.
+
+        :param encoding: The eventual encoding of the string. If this is None,
+            a Unicode string will be returned.
+        :param formatter: A Formatter object, or a string naming one of
+            the standard formatters.
+        :return: A Unicode string (if encoding==None) or a bytestring 
+            (otherwise).
+        """
+        if encoding is None:
+            return self.decode(True, formatter=formatter)
+        else:
+            return self.encode(encoding, True, formatter=formatter)
+
+    def decode_contents(self, indent_level=None,
+                       eventual_encoding=DEFAULT_OUTPUT_ENCODING,
+                       formatter="minimal"):
+        """Renders the contents of this tag as a Unicode string.
+
+        :param indent_level: Each line of the rendering will be
+           indented this many spaces. Used internally in
+           recursive calls while pretty-printing.
+
+        :param eventual_encoding: The tag is destined to be
+           encoded into this encoding. decode_contents() is _not_
+           responsible for performing that encoding. This information
+           is passed in so that it can be substituted in if the
+           document contains a  tag that mentions the document's
+           encoding.
+
+        :param formatter: A Formatter object, or a string naming one of
+            the standard Formatters.
+        """
+        # First off, turn a string formatter into a Formatter object. This
+        # will stop the lookup from happening over and over again.
+        if not isinstance(formatter, Formatter):
+            formatter = self.formatter_for_name(formatter)
+
+        pretty_print = (indent_level is not None)
+        s = []
+        for c in self:
+            text = None
+            if isinstance(c, NavigableString):
+                text = c.output_ready(formatter)
+            elif isinstance(c, Tag):
+                s.append(c.decode(indent_level, eventual_encoding,
+                                  formatter))
+            preserve_whitespace = (
+                self.preserve_whitespace_tags and self.name in self.preserve_whitespace_tags
+            )
+            if text and indent_level and not preserve_whitespace:
+                text = text.strip()
+            if text:
+                if pretty_print and not preserve_whitespace:
+                    s.append(" " * (indent_level - 1))
+                s.append(text)
+                if pretty_print and not preserve_whitespace:
+                    s.append("\n")
+        return ''.join(s)
+       
+    def encode_contents(
+        self, indent_level=None, encoding=DEFAULT_OUTPUT_ENCODING,
+        formatter="minimal"):
+        """Renders the contents of this PageElement as a bytestring.
+
+        :param indent_level: Each line of the rendering will be
+           indented this many spaces. Used internally in
+           recursive calls while pretty-printing.
+
+        :param eventual_encoding: The bytestring will be in this encoding.
+
+        :param formatter: A Formatter object, or a string naming one of
+            the standard Formatters.
+
+        :return: A bytestring.
+        """
+        contents = self.decode_contents(indent_level, encoding, formatter)
+        return contents.encode(encoding)
+
+    # Old method for BS3 compatibility
+    def renderContents(self, encoding=DEFAULT_OUTPUT_ENCODING,
+                       prettyPrint=False, indentLevel=0):
+        """Deprecated method for BS3 compatibility."""
+        if not prettyPrint:
+            indentLevel = None
+        return self.encode_contents(
+            indent_level=indentLevel, encoding=encoding)
+
+    #Soup methods
+
+    def find(self, name=None, attrs={}, recursive=True, text=None,
+             **kwargs):
+        """Look in the children of this PageElement and find the first
+        PageElement that matches the given criteria.
+
+        All find_* methods take a common set of arguments. See the online
+        documentation for detailed explanations.
+
+        :param name: A filter on tag name.
+        :param attrs: A dictionary of filters on attribute values.
+        :param recursive: If this is True, find() will perform a
+            recursive search of this PageElement's children. Otherwise,
+            only the direct children will be considered.
+        :param limit: Stop looking after finding this many results.
+        :kwargs: A dictionary of filters on attribute values.
+        :return: A PageElement.
+        :rtype: bs4.element.Tag | bs4.element.NavigableString
+        """
+        r = None
+        l = self.find_all(name, attrs, recursive, text, 1, **kwargs)
+        if l:
+            r = l[0]
+        return r
+    findChild = find #BS2
+
+    def find_all(self, name=None, attrs={}, recursive=True, text=None,
+                 limit=None, **kwargs):
+        """Look in the children of this PageElement and find all
+        PageElements that match the given criteria.
+
+        All find_* methods take a common set of arguments. See the online
+        documentation for detailed explanations.
+
+        :param name: A filter on tag name.
+        :param attrs: A dictionary of filters on attribute values.
+        :param recursive: If this is True, find_all() will perform a
+            recursive search of this PageElement's children. Otherwise,
+            only the direct children will be considered.
+        :param limit: Stop looking after finding this many results.
+        :kwargs: A dictionary of filters on attribute values.
+        :return: A ResultSet of PageElements.
+        :rtype: bs4.element.ResultSet
+        """
+        generator = self.descendants
+        if not recursive:
+            generator = self.children
+        return self._find_all(name, attrs, text, limit, generator, **kwargs)
+    findAll = find_all       # BS3
+    findChildren = find_all  # BS2
+
+    #Generator methods
+    @property
+    def children(self):
+        """Iterate over all direct children of this PageElement.
+
+        :yield: A sequence of PageElements.
+        """
+        # return iter() to make the purpose of the method clear
+        return iter(self.contents)  # XXX This seems to be untested.
+
+    @property
+    def descendants(self):
+        """Iterate over all children of this PageElement in a
+        breadth-first sequence.
+
+        :yield: A sequence of PageElements.
+        """
+        if not len(self.contents):
+            return
+        stopNode = self._last_descendant().next_element
+        current = self.contents[0]
+        while current is not stopNode:
+            yield current
+            current = current.next_element
+
+    # CSS selector code
+    def select_one(self, selector, namespaces=None, **kwargs):
+        """Perform a CSS selection operation on the current element.
+
+        :param selector: A CSS selector.
+
+        :param namespaces: A dictionary mapping namespace prefixes
+           used in the CSS selector to namespace URIs. By default,
+           Beautiful Soup will use the prefixes it encountered while
+           parsing the document.
+
+        :param kwargs: Keyword arguments to be passed into SoupSieve's 
+           soupsieve.select() method.
+
+        :return: A Tag.
+        :rtype: bs4.element.Tag
+        """
+        value = self.select(selector, namespaces, 1, **kwargs)
+        if value:
+            return value[0]
+        return None
+
+    def select(self, selector, namespaces=None, limit=None, **kwargs):
+        """Perform a CSS selection operation on the current element.
+
+        This uses the SoupSieve library.
+
+        :param selector: A string containing a CSS selector.
+
+        :param namespaces: A dictionary mapping namespace prefixes
+           used in the CSS selector to namespace URIs. By default,
+           Beautiful Soup will use the prefixes it encountered while
+           parsing the document.
+
+        :param limit: After finding this number of results, stop looking.
+
+        :param kwargs: Keyword arguments to be passed into SoupSieve's 
+           soupsieve.select() method.
+
+        :return: A ResultSet of Tags.
+        :rtype: bs4.element.ResultSet
+        """
+        if namespaces is None:
+            namespaces = self._namespaces
+        
+        if limit is None:
+            limit = 0
+        if soupsieve is None:
+            raise NotImplementedError(
+                "Cannot execute CSS selectors because the soupsieve package is not installed."
+            )
+            
+        results = soupsieve.select(selector, self, namespaces, limit, **kwargs)
+
+        # We do this because it's more consistent and because
+        # ResultSet.__getattr__ has a helpful error message.
+        return ResultSet(None, results)
+
+    # Old names for backwards compatibility
+    def childGenerator(self):
+        """Deprecated generator."""
+        return self.children
+
+    def recursiveChildGenerator(self):
+        """Deprecated generator."""
+        return self.descendants
+
+    def has_key(self, key):
+        """Deprecated method. This was kind of misleading because has_key()
+        (attributes) was different from __in__ (contents).
+
+        has_key() is gone in Python 3, anyway.
+        """
+        warnings.warn('has_key is deprecated. Use has_attr("%s") instead.' % (
+                key))
+        return self.has_attr(key)
+
+# Next, a couple classes to represent queries and their results.
+class SoupStrainer(object):
+    """Encapsulates a number of ways of matching a markup element (tag or
+    string).
+
+    This is primarily used to underpin the find_* methods, but you can
+    create one yourself and pass it in as `parse_only` to the
+    `BeautifulSoup` constructor, to parse a subset of a large
+    document.
+    """
+
+    def __init__(self, name=None, attrs={}, text=None, **kwargs):
+        """Constructor.
+
+        The SoupStrainer constructor takes the same arguments passed
+        into the find_* methods. See the online documentation for
+        detailed explanations.
+
+        :param name: A filter on tag name.
+        :param attrs: A dictionary of filters on attribute values.
+        :param text: A filter for a NavigableString with specific text.
+        :kwargs: A dictionary of filters on attribute values.
+        """        
+        self.name = self._normalize_search_value(name)
+        if not isinstance(attrs, dict):
+            # Treat a non-dict value for attrs as a search for the 'class'
+            # attribute.
+            kwargs['class'] = attrs
+            attrs = None
+
+        if 'class_' in kwargs:
+            # Treat class_="foo" as a search for the 'class'
+            # attribute, overriding any non-dict value for attrs.
+            kwargs['class'] = kwargs['class_']
+            del kwargs['class_']
+
+        if kwargs:
+            if attrs:
+                attrs = attrs.copy()
+                attrs.update(kwargs)
+            else:
+                attrs = kwargs
+        normalized_attrs = {}
+        for key, value in list(attrs.items()):
+            normalized_attrs[key] = self._normalize_search_value(value)
+
+        self.attrs = normalized_attrs
+        self.text = self._normalize_search_value(text)
+
+    def _normalize_search_value(self, value):
+        # Leave it alone if it's a Unicode string, a callable, a
+        # regular expression, a boolean, or None.
+        if (isinstance(value, str) or isinstance(value, Callable) or hasattr(value, 'match')
+            or isinstance(value, bool) or value is None):
+            return value
+
+        # If it's a bytestring, convert it to Unicode, treating it as UTF-8.
+        if isinstance(value, bytes):
+            return value.decode("utf8")
+
+        # If it's listlike, convert it into a list of strings.
+        if hasattr(value, '__iter__'):
+            new_value = []
+            for v in value:
+                if (hasattr(v, '__iter__') and not isinstance(v, bytes)
+                    and not isinstance(v, str)):
+                    # This is almost certainly the user's mistake. In the
+                    # interests of avoiding infinite loops, we'll let
+                    # it through as-is rather than doing a recursive call.
+                    new_value.append(v)
+                else:
+                    new_value.append(self._normalize_search_value(v))
+            return new_value
+
+        # Otherwise, convert it into a Unicode string.
+        # The unicode(str()) thing is so this will do the same thing on Python 2
+        # and Python 3.
+        return str(str(value))
+
+    def __str__(self):
+        """A human-readable representation of this SoupStrainer."""
+        if self.text:
+            return self.text
+        else:
+            return "%s|%s" % (self.name, self.attrs)
+
+    def search_tag(self, markup_name=None, markup_attrs={}):
+        """Check whether a Tag with the given name and attributes would
+        match this SoupStrainer.
+
+        Used prospectively to decide whether to even bother creating a Tag
+        object.
+
+        :param markup_name: A tag name as found in some markup.
+        :param markup_attrs: A dictionary of attributes as found in some markup.
+
+        :return: True if the prospective tag would match this SoupStrainer;
+            False otherwise.
+        """
+        found = None
+        markup = None
+        if isinstance(markup_name, Tag):
+            markup = markup_name
+            markup_attrs = markup
+
+        if isinstance(self.name, str):
+            # Optimization for a very common case where the user is
+            # searching for a tag with one specific name, and we're
+            # looking at a tag with a different name.
+            if markup and not markup.prefix and self.name != markup.name:
+                 return False
+            
+        call_function_with_tag_data = (
+            isinstance(self.name, Callable)
+            and not isinstance(markup_name, Tag))
+
+        if ((not self.name)
+            or call_function_with_tag_data
+            or (markup and self._matches(markup, self.name))
+            or (not markup and self._matches(markup_name, self.name))):
+            if call_function_with_tag_data:
+                match = self.name(markup_name, markup_attrs)
+            else:
+                match = True
+                markup_attr_map = None
+                for attr, match_against in list(self.attrs.items()):
+                    if not markup_attr_map:
+                        if hasattr(markup_attrs, 'get'):
+                            markup_attr_map = markup_attrs
+                        else:
+                            markup_attr_map = {}
+                            for k, v in markup_attrs:
+                                markup_attr_map[k] = v
+                    attr_value = markup_attr_map.get(attr)
+                    if not self._matches(attr_value, match_against):
+                        match = False
+                        break
+            if match:
+                if markup:
+                    found = markup
+                else:
+                    found = markup_name
+        if found and self.text and not self._matches(found.string, self.text):
+            found = None
+        return found
+
+    # For BS3 compatibility.
+    searchTag = search_tag
+
+    def search(self, markup):
+        """Find all items in `markup` that match this SoupStrainer.
+
+        Used by the core _find_all() method, which is ultimately
+        called by all find_* methods.
+
+        :param markup: A PageElement or a list of them.
+        """
+        # print('looking for %s in %s' % (self, markup))
+        found = None
+        # If given a list of items, scan it for a text element that
+        # matches.
+        if hasattr(markup, '__iter__') and not isinstance(markup, (Tag, str)):
+            for element in markup:
+                if isinstance(element, NavigableString) \
+                       and self.search(element):
+                    found = element
+                    break
+        # If it's a Tag, make sure its name or attributes match.
+        # Don't bother with Tags if we're searching for text.
+        elif isinstance(markup, Tag):
+            if not self.text or self.name or self.attrs:
+                found = self.search_tag(markup)
+        # If it's text, make sure the text matches.
+        elif isinstance(markup, NavigableString) or \
+                 isinstance(markup, str):
+            if not self.name and not self.attrs and self._matches(markup, self.text):
+                found = markup
+        else:
+            raise Exception(
+                "I don't know how to match against a %s" % markup.__class__)
+        return found
+
+    def _matches(self, markup, match_against, already_tried=None):
+        # print(u"Matching %s against %s" % (markup, match_against))
+        result = False
+        if isinstance(markup, list) or isinstance(markup, tuple):
+            # This should only happen when searching a multi-valued attribute
+            # like 'class'.
+            for item in markup:
+                if self._matches(item, match_against):
+                    return True
+            # We didn't match any particular value of the multivalue
+            # attribute, but maybe we match the attribute value when
+            # considered as a string.
+            if self._matches(' '.join(markup), match_against):
+                return True
+            return False
+        
+        if match_against is True:
+            # True matches any non-None value.
+            return markup is not None
+
+        if isinstance(match_against, Callable):
+            return match_against(markup)
+
+        # Custom callables take the tag as an argument, but all
+        # other ways of matching match the tag name as a string.
+        original_markup = markup
+        if isinstance(markup, Tag):
+            markup = markup.name
+
+        # Ensure that `markup` is either a Unicode string, or None.
+        markup = self._normalize_search_value(markup)
+
+        if markup is None:
+            # None matches None, False, an empty string, an empty list, and so on.
+            return not match_against
+
+        if (hasattr(match_against, '__iter__')
+            and not isinstance(match_against, str)):
+            # We're asked to match against an iterable of items.
+            # The markup must be match at least one item in the
+            # iterable. We'll try each one in turn.
+            #
+            # To avoid infinite recursion we need to keep track of
+            # items we've already seen.
+            if not already_tried:
+                already_tried = set()
+            for item in match_against:
+                if item.__hash__:
+                    key = item
+                else:
+                    key = id(item)
+                if key in already_tried:
+                    continue
+                else:
+                    already_tried.add(key)
+                    if self._matches(original_markup, item, already_tried):
+                        return True
+            else:
+                return False
+        
+        # Beyond this point we might need to run the test twice: once against
+        # the tag's name and once against its prefixed name.
+        match = False
+        
+        if not match and isinstance(match_against, str):
+            # Exact string match
+            match = markup == match_against
+
+        if not match and hasattr(match_against, 'search'):
+            # Regexp match
+            return match_against.search(markup)
+
+        if (not match
+            and isinstance(original_markup, Tag)
+            and original_markup.prefix):
+            # Try the whole thing again with the prefixed tag name.
+            return self._matches(
+                original_markup.prefix + ':' + original_markup.name, match_against
+            )
+
+        return match
+
+
+class ResultSet(list):
+    """A ResultSet is just a list that keeps track of the SoupStrainer
+    that created it."""
+    def __init__(self, source, result=()):
+        """Constructor.
+
+        :param source: A SoupStrainer.
+        :param result: A list of PageElements.
+        """
+        super(ResultSet, self).__init__(result)
+        self.source = source
+
+    def __getattr__(self, key):
+        """Raise a helpful exception to explain a common code fix."""
+        raise AttributeError(
+            "ResultSet object has no attribute '%s'. You're probably treating a list of elements like a single element. Did you call find_all() when you meant to call find()?" % key
+        )
diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/formatter.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/formatter.py
new file mode 100644
index 00000000..3bd9f859
--- /dev/null
+++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bs4/formatter.py
@@ -0,0 +1,165 @@
+from bs4.dammit import EntitySubstitution
+
+class Formatter(EntitySubstitution):
+    """Describes a strategy to use when outputting a parse tree to a string.
+
+    Some parts of this strategy come from the distinction between
+    HTML4, HTML5, and XML. Others are configurable by the user.
+
+    Formatters are passed in as the `formatter` argument to methods
+    like `PageElement.encode`. Most people won't need to think about
+    formatters, and most people who need to think about them can pass
+    in one of these predefined strings as `formatter` rather than
+    making a new Formatter object:
+
+    For HTML documents:
+     * 'html' - HTML entity substitution for generic HTML documents. (default)
+     * 'html5' - HTML entity substitution for HTML5 documents, as
+                 well as some optimizations in the way tags are rendered.
+     * 'minimal' - Only make the substitutions necessary to guarantee
+                   valid HTML.
+     * None - Do not perform any substitution. This will be faster
+              but may result in invalid markup.
+
+    For XML documents:
+     * 'html' - Entity substitution for XHTML documents.
+     * 'minimal' - Only make the substitutions necessary to guarantee
+                   valid XML. (default)
+     * None - Do not perform any substitution. This will be faster
+              but may result in invalid markup.
+    """
+    # Registries of XML and HTML formatters.
+    XML_FORMATTERS = {}
+    HTML_FORMATTERS = {}
+
+    HTML = 'html'
+    XML = 'xml'
+
+    HTML_DEFAULTS = dict(
+        cdata_containing_tags=set(["script", "style"]),
+    )
+
+    def _default(self, language, value, kwarg):
+        if value is not None:
+            return value
+        if language == self.XML:
+            return set()
+        return self.HTML_DEFAULTS[kwarg]
+
+    def __init__(
+            self, language=None, entity_substitution=None,
+            void_element_close_prefix='/', cdata_containing_tags=None,
+            empty_attributes_are_booleans=False,
+    ):
+        """Constructor.
+
+        :param language: This should be Formatter.XML if you are formatting
+           XML markup and Formatter.HTML if you are formatting HTML markup.
+
+        :param entity_substitution: A function to call to replace special
+           characters with XML/HTML entities. For examples, see 
+           bs4.dammit.EntitySubstitution.substitute_html and substitute_xml.
+        :param void_element_close_prefix: By default, void elements
+           are represented as  (XML rules) rather than 
+           (HTML rules). To get , pass in the empty string.
+        :param cdata_containing_tags: The list of tags that are defined
+           as containing CDATA in this dialect. For example, in HTML,
+           
+
This numeric entity is missing the final semicolon:
+ +
a
+
This document contains (do you see it?)
+
This document ends with That attribute value was bogus
+The doctype is invalid because it contains extra whitespace +
That boolean attribute had no value
+
Here's a nonexistent entity: &#foo; (do you see it?)
+
This document ends before the entity finishes: > +

Paragraphs shouldn't contain block display elements, but this one does:

you see?

+Multiple values for the same attribute. +
Here's a table
+
+
This tag contains nothing but whitespace:
+

This p tag is cut off by

the end of the blockquote tag
+
Here's a nested table:
foo
This table contains bare markup
+ +
This document contains a surprise doctype
+ +
Tag name contains Unicode characters
+ + +""" + + +class SoupTest(unittest.TestCase): + + @property + def default_builder(self): + return default_builder + + def soup(self, markup, **kwargs): + """Build a Beautiful Soup object from markup.""" + builder = kwargs.pop('builder', self.default_builder) + return BeautifulSoup(markup, builder=builder, **kwargs) + + def document_for(self, markup, **kwargs): + """Turn an HTML fragment into a document. + + The details depend on the builder. + """ + return self.default_builder(**kwargs).test_fragment_to_document(markup) + + def assertSoupEquals(self, to_parse, compare_parsed_to=None): + builder = self.default_builder + obj = BeautifulSoup(to_parse, builder=builder) + if compare_parsed_to is None: + compare_parsed_to = to_parse + + # Verify that the documents come out the same. + self.assertEqual(obj.decode(), self.document_for(compare_parsed_to)) + + # Also run some checks on the BeautifulSoup object itself: + + # Verify that every tag that was opened was eventually closed. + + # There are no tags in the open tag counter. + assert all(v==0 for v in list(obj.open_tag_counter.values())) + + # The only tag in the tag stack is the one for the root + # document. + self.assertEqual( + [obj.ROOT_TAG_NAME], [x.name for x in obj.tagStack] + ) + + def assertConnectedness(self, element): + """Ensure that next_element and previous_element are properly + set for all descendants of the given element. + """ + earlier = None + for e in element.descendants: + if earlier: + self.assertEqual(e, earlier.next_element) + self.assertEqual(earlier, e.previous_element) + earlier = e + + def linkage_validator(self, el, _recursive_call=False): + """Ensure proper linkage throughout the document.""" + descendant = None + # Document element should have no previous element or previous sibling. + # It also shouldn't have a next sibling. + if el.parent is None: + assert el.previous_element is None,\ + "Bad previous_element\nNODE: {}\nPREV: {}\nEXPECTED: {}".format( + el, el.previous_element, None + ) + assert el.previous_sibling is None,\ + "Bad previous_sibling\nNODE: {}\nPREV: {}\nEXPECTED: {}".format( + el, el.previous_sibling, None + ) + assert el.next_sibling is None,\ + "Bad next_sibling\nNODE: {}\nNEXT: {}\nEXPECTED: {}".format( + el, el.next_sibling, None + ) + + idx = 0 + child = None + last_child = None + last_idx = len(el.contents) - 1 + for child in el.contents: + descendant = None + + # Parent should link next element to their first child + # That child should have no previous sibling + if idx == 0: + if el.parent is not None: + assert el.next_element is child,\ + "Bad next_element\nNODE: {}\nNEXT: {}\nEXPECTED: {}".format( + el, el.next_element, child + ) + assert child.previous_element is el,\ + "Bad previous_element\nNODE: {}\nPREV: {}\nEXPECTED: {}".format( + child, child.previous_element, el + ) + assert child.previous_sibling is None,\ + "Bad previous_sibling\nNODE: {}\nPREV {}\nEXPECTED: {}".format( + child, child.previous_sibling, None + ) + + # If not the first child, previous index should link as sibling to this index + # Previous element should match the last index or the last bubbled up descendant + else: + assert child.previous_sibling is el.contents[idx - 1],\ + "Bad previous_sibling\nNODE: {}\nPREV {}\nEXPECTED {}".format( + child, child.previous_sibling, el.contents[idx - 1] + ) + assert el.contents[idx - 1].next_sibling is child,\ + "Bad next_sibling\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + el.contents[idx - 1], el.contents[idx - 1].next_sibling, child + ) + + if last_child is not None: + assert child.previous_element is last_child,\ + "Bad previous_element\nNODE: {}\nPREV {}\nEXPECTED {}\nCONTENTS {}".format( + child, child.previous_element, last_child, child.parent.contents + ) + assert last_child.next_element is child,\ + "Bad next_element\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + last_child, last_child.next_element, child + ) + + if isinstance(child, Tag) and child.contents: + descendant = self.linkage_validator(child, True) + # A bubbled up descendant should have no next siblings + assert descendant.next_sibling is None,\ + "Bad next_sibling\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + descendant, descendant.next_sibling, None + ) + + # Mark last child as either the bubbled up descendant or the current child + if descendant is not None: + last_child = descendant + else: + last_child = child + + # If last child, there are non next siblings + if idx == last_idx: + assert child.next_sibling is None,\ + "Bad next_sibling\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + child, child.next_sibling, None + ) + idx += 1 + + child = descendant if descendant is not None else child + if child is None: + child = el + + if not _recursive_call and child is not None: + target = el + while True: + if target is None: + assert child.next_element is None, \ + "Bad next_element\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + child, child.next_element, None + ) + break + elif target.next_sibling is not None: + assert child.next_element is target.next_sibling, \ + "Bad next_element\nNODE: {}\nNEXT {}\nEXPECTED {}".format( + child, child.next_element, target.next_sibling + ) + break + target = target.parent + + # We are done, so nothing to return + return None + else: + # Return the child to the recursive caller + return child + + +class TreeBuilderSmokeTest(object): + # Tests that are common to HTML and XML tree builders. + + def test_fuzzed_input(self): + # This test centralizes in one place the various fuzz tests + # for Beautiful Soup created by the oss-fuzz project. + + # These strings superficially resemble markup, but they + # generally can't be parsed into anything. The best we can + # hope for is that parsing these strings won't crash the + # parser. + # + # n.b. This markup is commented out because these fuzz tests + # _do_ crash the parser. However the crashes are due to bugs + # in html.parser, not Beautiful Soup -- otherwise I'd fix the + # bugs! + + bad_markup = [ + # https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=28873 + # https://github.com/guidovranken/python-library-fuzzers/blob/master/corp-html/519e5b4269a01185a0d5e76295251921da2f0700 + # https://bugs.python.org/issue37747 + # + #b'\nSome CSS" + ) + assert isinstance(soup.style.string, Stylesheet) + assert isinstance(soup.script.string, Script) + + soup = self.soup( + "" + ) + assert isinstance(soup.style.string, Stylesheet) + # The contents of the style tag resemble an HTML comment, but + # it's not treated as a comment. + self.assertEqual("", soup.style.string) + assert isinstance(soup.style.string, Stylesheet) + + def test_pickle_and_unpickle_identity(self): + # Pickling a tree, then unpickling it, yields a tree identical + # to the original. + tree = self.soup("foo") + dumped = pickle.dumps(tree, 2) + loaded = pickle.loads(dumped) + self.assertEqual(loaded.__class__, BeautifulSoup) + self.assertEqual(loaded.decode(), tree.decode()) + + def assertDoctypeHandled(self, doctype_fragment): + """Assert that a given doctype string is handled correctly.""" + doctype_str, soup = self._document_with_doctype(doctype_fragment) + + # Make sure a Doctype object was created. + doctype = soup.contents[0] + self.assertEqual(doctype.__class__, Doctype) + self.assertEqual(doctype, doctype_fragment) + self.assertEqual( + soup.encode("utf8")[:len(doctype_str)], + doctype_str + ) + + # Make sure that the doctype was correctly associated with the + # parse tree and that the rest of the document parsed. + self.assertEqual(soup.p.contents[0], 'foo') + + def _document_with_doctype(self, doctype_fragment, doctype_string="DOCTYPE"): + """Generate and parse a document with the given doctype.""" + doctype = '' % (doctype_string, doctype_fragment) + markup = doctype + '\n

foo

' + soup = self.soup(markup) + return doctype.encode("utf8"), soup + + def test_normal_doctypes(self): + """Make sure normal, everyday HTML doctypes are handled correctly.""" + self.assertDoctypeHandled("html") + self.assertDoctypeHandled( + 'html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"') + + def test_empty_doctype(self): + soup = self.soup("") + doctype = soup.contents[0] + self.assertEqual("", doctype.strip()) + + def test_mixed_case_doctype(self): + # A lowercase or mixed-case doctype becomes a Doctype. + for doctype_fragment in ("doctype", "DocType"): + doctype_str, soup = self._document_with_doctype( + "html", doctype_fragment + ) + + # Make sure a Doctype object was created and that the DOCTYPE + # is uppercase. + doctype = soup.contents[0] + self.assertEqual(doctype.__class__, Doctype) + self.assertEqual(doctype, "html") + self.assertEqual( + soup.encode("utf8")[:len(doctype_str)], + b"" + ) + + # Make sure that the doctype was correctly associated with the + # parse tree and that the rest of the document parsed. + self.assertEqual(soup.p.contents[0], 'foo') + + def test_public_doctype_with_url(self): + doctype = 'html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"' + self.assertDoctypeHandled(doctype) + + def test_system_doctype(self): + self.assertDoctypeHandled('foo SYSTEM "http://www.example.com/"') + + def test_namespaced_system_doctype(self): + # We can handle a namespaced doctype with a system ID. + self.assertDoctypeHandled('xsl:stylesheet SYSTEM "htmlent.dtd"') + + def test_namespaced_public_doctype(self): + # Test a namespaced doctype with a public id. + self.assertDoctypeHandled('xsl:stylesheet PUBLIC "htmlent.dtd"') + + def test_real_xhtml_document(self): + """A real XHTML document should come out more or less the same as it went in.""" + markup = b""" + + +Hello. +Goodbye. +""" + soup = self.soup(markup) + self.assertEqual( + soup.encode("utf-8").replace(b"\n", b""), + markup.replace(b"\n", b"")) + + def test_namespaced_html(self): + """When a namespaced XML document is parsed as HTML it should + be treated as HTML with weird tag names. + """ + markup = b"""content""" + soup = self.soup(markup) + self.assertEqual(2, len(soup.find_all("ns1:foo"))) + + def test_processing_instruction(self): + # We test both Unicode and bytestring to verify that + # process_markup correctly sets processing_instruction_class + # even when the markup is already Unicode and there is no + # need to process anything. + markup = """""" + soup = self.soup(markup) + self.assertEqual(markup, soup.decode()) + + markup = b"""""" + soup = self.soup(markup) + self.assertEqual(markup, soup.encode("utf8")) + + def test_deepcopy(self): + """Make sure you can copy the tree builder. + + This is important because the builder is part of a + BeautifulSoup object, and we want to be able to copy that. + """ + copy.deepcopy(self.default_builder) + + def test_p_tag_is_never_empty_element(self): + """A

tag is never designated as an empty-element tag. + + Even if the markup shows it as an empty-element tag, it + shouldn't be presented that way. + """ + soup = self.soup("

") + self.assertFalse(soup.p.is_empty_element) + self.assertEqual(str(soup.p), "

") + + def test_unclosed_tags_get_closed(self): + """A tag that's not closed by the end of the document should be closed. + + This applies to all tags except empty-element tags. + """ + self.assertSoupEquals("

", "

") + self.assertSoupEquals("", "") + + self.assertSoupEquals("
", "
") + + def test_br_is_always_empty_element_tag(self): + """A
tag is designated as an empty-element tag. + + Some parsers treat

as one
tag, some parsers as + two tags, but it should always be an empty-element tag. + """ + soup = self.soup("

") + self.assertTrue(soup.br.is_empty_element) + self.assertEqual(str(soup.br), "
") + + def test_nested_formatting_elements(self): + self.assertSoupEquals("") + + def test_double_head(self): + html = ''' + + +Ordinary HEAD element test + + + +Hello, world! + + +''' + soup = self.soup(html) + self.assertEqual("text/javascript", soup.find('script')['type']) + + def test_comment(self): + # Comments are represented as Comment objects. + markup = "

foobaz

" + self.assertSoupEquals(markup) + + soup = self.soup(markup) + comment = soup.find(text="foobar") + self.assertEqual(comment.__class__, Comment) + + # The comment is properly integrated into the tree. + foo = soup.find(text="foo") + self.assertEqual(comment, foo.next_element) + baz = soup.find(text="baz") + self.assertEqual(comment, baz.previous_element) + + def test_preserved_whitespace_in_pre_and_textarea(self): + """Whitespace must be preserved in
 and "
+        self.assertSoupEquals(pre_markup)
+        self.assertSoupEquals(textarea_markup)
+
+        soup = self.soup(pre_markup)
+        self.assertEqual(soup.pre.prettify(), pre_markup)
+
+        soup = self.soup(textarea_markup)
+        self.assertEqual(soup.textarea.prettify(), textarea_markup)
+
+        soup = self.soup("")
+        self.assertEqual(soup.textarea.prettify(), "")
+
+    def test_nested_inline_elements(self):
+        """Inline elements can be nested indefinitely."""
+        b_tag = "Inside a B tag"
+        self.assertSoupEquals(b_tag)
+
+        nested_b_tag = "

A nested tag

" + self.assertSoupEquals(nested_b_tag) + + double_nested_b_tag = "

A doubly nested tag

" + self.assertSoupEquals(nested_b_tag) + + def test_nested_block_level_elements(self): + """Block elements can be nested.""" + soup = self.soup('

Foo

') + blockquote = soup.blockquote + self.assertEqual(blockquote.p.b.string, 'Foo') + self.assertEqual(blockquote.b.string, 'Foo') + + def test_correctly_nested_tables(self): + """One table can go inside another one.""" + markup = ('' + '' + "') + + self.assertSoupEquals( + markup, + '
Here's another table:" + '' + '' + '
foo
Here\'s another table:' + '
foo
' + '
') + + self.assertSoupEquals( + "" + "" + "
Foo
Bar
Baz
") + + def test_multivalued_attribute_with_whitespace(self): + # Whitespace separating the values of a multi-valued attribute + # should be ignored. + + markup = '
' + soup = self.soup(markup) + self.assertEqual(['foo', 'bar'], soup.div['class']) + + # If you search by the literal name of the class it's like the whitespace + # wasn't there. + self.assertEqual(soup.div, soup.find('div', class_="foo bar")) + + def test_deeply_nested_multivalued_attribute(self): + # html5lib can set the attributes of the same tag many times + # as it rearranges the tree. This has caused problems with + # multivalued attributes. + markup = '
' + soup = self.soup(markup) + self.assertEqual(["css"], soup.div.div['class']) + + def test_multivalued_attribute_on_html(self): + # html5lib uses a different API to set the attributes ot the + # tag. This has caused problems with multivalued + # attributes. + markup = '' + soup = self.soup(markup) + self.assertEqual(["a", "b"], soup.html['class']) + + def test_angle_brackets_in_attribute_values_are_escaped(self): + self.assertSoupEquals('', '') + + def test_strings_resembling_character_entity_references(self): + # "&T" and "&p" look like incomplete character entities, but they are + # not. + self.assertSoupEquals( + "

• AT&T is in the s&p 500

", + "

\u2022 AT&T is in the s&p 500

" + ) + + def test_apos_entity(self): + self.assertSoupEquals( + "

Bob's Bar

", + "

Bob's Bar

", + ) + + def test_entities_in_foreign_document_encoding(self): + # “ and ” are invalid numeric entities referencing + # Windows-1252 characters. - references a character common + # to Windows-1252 and Unicode, and ☃ references a + # character only found in Unicode. + # + # All of these entities should be converted to Unicode + # characters. + markup = "

“Hello” -☃

" + soup = self.soup(markup) + self.assertEqual("“Hello†-☃", soup.p.string) + + def test_entities_in_attributes_converted_to_unicode(self): + expect = '

' + self.assertSoupEquals('

', expect) + self.assertSoupEquals('

', expect) + self.assertSoupEquals('

', expect) + self.assertSoupEquals('

', expect) + + def test_entities_in_text_converted_to_unicode(self): + expect = '

pi\N{LATIN SMALL LETTER N WITH TILDE}ata

' + self.assertSoupEquals("

piñata

", expect) + self.assertSoupEquals("

piñata

", expect) + self.assertSoupEquals("

piñata

", expect) + self.assertSoupEquals("

piñata

", expect) + + def test_quot_entity_converted_to_quotation_mark(self): + self.assertSoupEquals("

I said "good day!"

", + '

I said "good day!"

') + + def test_out_of_range_entity(self): + expect = "\N{REPLACEMENT CHARACTER}" + self.assertSoupEquals("�", expect) + self.assertSoupEquals("�", expect) + self.assertSoupEquals("�", expect) + + def test_multipart_strings(self): + "Mostly to prevent a recurrence of a bug in the html5lib treebuilder." + soup = self.soup("

\nfoo

") + self.assertEqual("p", soup.h2.string.next_element.name) + self.assertEqual("p", soup.p.name) + self.assertConnectedness(soup) + + def test_empty_element_tags(self): + """Verify consistent handling of empty-element tags, + no matter how they come in through the markup. + """ + self.assertSoupEquals('


', "


") + self.assertSoupEquals('


', "


") + + def test_head_tag_between_head_and_body(self): + "Prevent recurrence of a bug in the html5lib treebuilder." + content = """ + + foo + +""" + soup = self.soup(content) + self.assertNotEqual(None, soup.html.body) + self.assertConnectedness(soup) + + def test_multiple_copies_of_a_tag(self): + "Prevent recurrence of a bug in the html5lib treebuilder." + content = """ + + + + + +""" + soup = self.soup(content) + self.assertConnectedness(soup.article) + + def test_basic_namespaces(self): + """Parsers don't need to *understand* namespaces, but at the + very least they should not choke on namespaces or lose + data.""" + + markup = b'4' + soup = self.soup(markup) + self.assertEqual(markup, soup.encode()) + html = soup.html + self.assertEqual('http://www.w3.org/1999/xhtml', soup.html['xmlns']) + self.assertEqual( + 'http://www.w3.org/1998/Math/MathML', soup.html['xmlns:mathml']) + self.assertEqual( + 'http://www.w3.org/2000/svg', soup.html['xmlns:svg']) + + def test_multivalued_attribute_value_becomes_list(self): + markup = b'' + soup = self.soup(markup) + self.assertEqual(['foo', 'bar'], soup.a['class']) + + # + # Generally speaking, tests below this point are more tests of + # Beautiful Soup than tests of the tree builders. But parsers are + # weird, so we run these tests separately for every tree builder + # to detect any differences between them. + # + + def test_can_parse_unicode_document(self): + # A seemingly innocuous document... but it's in Unicode! And + # it contains characters that can't be represented in the + # encoding found in the declaration! The horror! + markup = 'Sacr\N{LATIN SMALL LETTER E WITH ACUTE} bleu!' + soup = self.soup(markup) + self.assertEqual('Sacr\xe9 bleu!', soup.body.string) + + def test_soupstrainer(self): + """Parsers should be able to work with SoupStrainers.""" + strainer = SoupStrainer("b") + soup = self.soup("A bold statement", + parse_only=strainer) + self.assertEqual(soup.decode(), "bold") + + def test_single_quote_attribute_values_become_double_quotes(self): + self.assertSoupEquals("", + '') + + def test_attribute_values_with_nested_quotes_are_left_alone(self): + text = """a""" + self.assertSoupEquals(text) + + def test_attribute_values_with_double_nested_quotes_get_quoted(self): + text = """a""" + soup = self.soup(text) + soup.foo['attr'] = 'Brawls happen at "Bob\'s Bar"' + self.assertSoupEquals( + soup.foo.decode(), + """a""") + + def test_ampersand_in_attribute_value_gets_escaped(self): + self.assertSoupEquals('', + '') + + self.assertSoupEquals( + 'foo', + 'foo') + + def test_escaped_ampersand_in_attribute_value_is_left_alone(self): + self.assertSoupEquals('') + + def test_entities_in_strings_converted_during_parsing(self): + # Both XML and HTML entities are converted to Unicode characters + # during parsing. + text = "

<<sacré bleu!>>

" + expected = "

<<sacr\N{LATIN SMALL LETTER E WITH ACUTE} bleu!>>

" + self.assertSoupEquals(text, expected) + + def test_smart_quotes_converted_on_the_way_in(self): + # Microsoft smart quotes are converted to Unicode characters during + # parsing. + quote = b"

\x91Foo\x92

" + soup = self.soup(quote) + self.assertEqual( + soup.p.string, + "\N{LEFT SINGLE QUOTATION MARK}Foo\N{RIGHT SINGLE QUOTATION MARK}") + + def test_non_breaking_spaces_converted_on_the_way_in(self): + soup = self.soup("  ") + self.assertEqual(soup.a.string, "\N{NO-BREAK SPACE}" * 2) + + def test_entities_converted_on_the_way_out(self): + text = "

<<sacré bleu!>>

" + expected = "

<<sacr\N{LATIN SMALL LETTER E WITH ACUTE} bleu!>>

".encode("utf-8") + soup = self.soup(text) + self.assertEqual(soup.p.encode("utf-8"), expected) + + def test_real_iso_latin_document(self): + # Smoke test of interrelated functionality, using an + # easy-to-understand document. + + # Here it is in Unicode. Note that it claims to be in ISO-Latin-1. + unicode_html = '

Sacr\N{LATIN SMALL LETTER E WITH ACUTE} bleu!

' + + # That's because we're going to encode it into ISO-Latin-1, and use + # that to test. + iso_latin_html = unicode_html.encode("iso-8859-1") + + # Parse the ISO-Latin-1 HTML. + soup = self.soup(iso_latin_html) + # Encode it to UTF-8. + result = soup.encode("utf-8") + + # What do we expect the result to look like? Well, it would + # look like unicode_html, except that the META tag would say + # UTF-8 instead of ISO-Latin-1. + expected = unicode_html.replace("ISO-Latin-1", "utf-8") + + # And, of course, it would be in UTF-8, not Unicode. + expected = expected.encode("utf-8") + + # Ta-da! + self.assertEqual(result, expected) + + def test_real_shift_jis_document(self): + # Smoke test to make sure the parser can handle a document in + # Shift-JIS encoding, without choking. + shift_jis_html = ( + b'
'
+            b'\x82\xb1\x82\xea\x82\xcdShift-JIS\x82\xc5\x83R\x81[\x83f'
+            b'\x83B\x83\x93\x83O\x82\xb3\x82\xea\x82\xbd\x93\xfa\x96{\x8c'
+            b'\xea\x82\xcc\x83t\x83@\x83C\x83\x8b\x82\xc5\x82\xb7\x81B'
+            b'
') + unicode_html = shift_jis_html.decode("shift-jis") + soup = self.soup(unicode_html) + + # Make sure the parse tree is correctly encoded to various + # encodings. + self.assertEqual(soup.encode("utf-8"), unicode_html.encode("utf-8")) + self.assertEqual(soup.encode("euc_jp"), unicode_html.encode("euc_jp")) + + def test_real_hebrew_document(self): + # A real-world test to make sure we can convert ISO-8859-9 (a + # Hebrew encoding) to UTF-8. + hebrew_document = b'Hebrew (ISO 8859-8) in Visual Directionality

Hebrew (ISO 8859-8) in Visual Directionality

\xed\xe5\xec\xf9' + soup = self.soup( + hebrew_document, from_encoding="iso8859-8") + # Some tree builders call it iso8859-8, others call it iso-8859-9. + # That's not a difference we really care about. + assert soup.original_encoding in ('iso8859-8', 'iso-8859-8') + self.assertEqual( + soup.encode('utf-8'), + hebrew_document.decode("iso8859-8").encode("utf-8")) + + def test_meta_tag_reflects_current_encoding(self): + # Here's the tag saying that a document is + # encoded in Shift-JIS. + meta_tag = ('') + + # Here's a document incorporating that meta tag. + shift_jis_html = ( + '\n%s\n' + '' + 'Shift-JIS markup goes here.') % meta_tag + soup = self.soup(shift_jis_html) + + # Parse the document, and the charset is seemingly unaffected. + parsed_meta = soup.find('meta', {'http-equiv': 'Content-type'}) + content = parsed_meta['content'] + self.assertEqual('text/html; charset=x-sjis', content) + + # But that value is actually a ContentMetaAttributeValue object. + self.assertTrue(isinstance(content, ContentMetaAttributeValue)) + + # And it will take on a value that reflects its current + # encoding. + self.assertEqual('text/html; charset=utf8', content.encode("utf8")) + + # For the rest of the story, see TestSubstitutions in + # test_tree.py. + + def test_html5_style_meta_tag_reflects_current_encoding(self): + # Here's the tag saying that a document is + # encoded in Shift-JIS. + meta_tag = ('') + + # Here's a document incorporating that meta tag. + shift_jis_html = ( + '\n%s\n' + '' + 'Shift-JIS markup goes here.') % meta_tag + soup = self.soup(shift_jis_html) + + # Parse the document, and the charset is seemingly unaffected. + parsed_meta = soup.find('meta', id="encoding") + charset = parsed_meta['charset'] + self.assertEqual('x-sjis', charset) + + # But that value is actually a CharsetMetaAttributeValue object. + self.assertTrue(isinstance(charset, CharsetMetaAttributeValue)) + + # And it will take on a value that reflects its current + # encoding. + self.assertEqual('utf8', charset.encode("utf8")) + + def test_python_specific_encodings_not_used_in_charset(self): + # You can encode an HTML document using a Python-specific + # encoding, but that encoding won't be mentioned _inside_ the + # resulting document. Instead, the document will appear to + # have no encoding. + for markup in [ + b'' + b'' + ]: + soup = self.soup(markup) + for encoding in PYTHON_SPECIFIC_ENCODINGS: + if encoding in ( + 'idna', 'mbcs', 'oem', 'undefined', + 'string_escape', 'string-escape' + ): + # For one reason or another, these will raise an + # exception if we actually try to use them, so don't + # bother. + continue + encoded = soup.encode(encoding) + assert b'meta charset=""' in encoded + assert encoding.encode("ascii") not in encoded + + def test_tag_with_no_attributes_can_have_attributes_added(self): + data = self.soup("text") + data.a['foo'] = 'bar' + self.assertEqual('text', data.a.decode()) + + def test_closing_tag_with_no_opening_tag(self): + # Without BeautifulSoup.open_tag_counter, the tag will + # cause _popToTag to be called over and over again as we look + # for a tag that wasn't there. The result is that 'text2' + # will show up outside the body of the document. + soup = self.soup("

text1

text2
") + self.assertEqual( + "

text1

text2
", soup.body.decode() + ) + + def test_worst_case(self): + """Test the worst case (currently) for linking issues.""" + + soup = self.soup(BAD_DOCUMENT) + self.linkage_validator(soup) + + +class XMLTreeBuilderSmokeTest(TreeBuilderSmokeTest): + + def test_pickle_and_unpickle_identity(self): + # Pickling a tree, then unpickling it, yields a tree identical + # to the original. + tree = self.soup("foo") + dumped = pickle.dumps(tree, 2) + loaded = pickle.loads(dumped) + self.assertEqual(loaded.__class__, BeautifulSoup) + self.assertEqual(loaded.decode(), tree.decode()) + + def test_docstring_generated(self): + soup = self.soup("") + self.assertEqual( + soup.encode(), b'\n') + + def test_xml_declaration(self): + markup = b"""\n""" + soup = self.soup(markup) + self.assertEqual(markup, soup.encode("utf8")) + + def test_python_specific_encodings_not_used_in_xml_declaration(self): + # You can encode an XML document using a Python-specific + # encoding, but that encoding won't be mentioned _inside_ the + # resulting document. + markup = b"""\n""" + soup = self.soup(markup) + for encoding in PYTHON_SPECIFIC_ENCODINGS: + if encoding in ( + 'idna', 'mbcs', 'oem', 'undefined', + 'string_escape', 'string-escape' + ): + # For one reason or another, these will raise an + # exception if we actually try to use them, so don't + # bother. + continue + encoded = soup.encode(encoding) + assert b'' in encoded + assert encoding.encode("ascii") not in encoded + + def test_processing_instruction(self): + markup = b"""\n""" + soup = self.soup(markup) + self.assertEqual(markup, soup.encode("utf8")) + + def test_real_xhtml_document(self): + """A real XHTML document should come out *exactly* the same as it went in.""" + markup = b""" + + +Hello. +Goodbye. +""" + soup = self.soup(markup) + self.assertEqual( + soup.encode("utf-8"), markup) + + def test_nested_namespaces(self): + doc = b""" + + + + + +""" + soup = self.soup(doc) + self.assertEqual(doc, soup.encode()) + + def test_formatter_processes_script_tag_for_xml_documents(self): + doc = """ + +""" + soup = BeautifulSoup(doc, "lxml-xml") + # lxml would have stripped this while parsing, but we can add + # it later. + soup.script.string = 'console.log("< < hey > > ");' + encoded = soup.encode() + self.assertTrue(b"< < hey > >" in encoded) + + def test_can_parse_unicode_document(self): + markup = 'Sacr\N{LATIN SMALL LETTER E WITH ACUTE} bleu!' + soup = self.soup(markup) + self.assertEqual('Sacr\xe9 bleu!', soup.root.string) + + def test_popping_namespaced_tag(self): + markup = 'b2012-07-02T20:33:42Zcd' + soup = self.soup(markup) + self.assertEqual( + str(soup.rss), markup) + + def test_docstring_includes_correct_encoding(self): + soup = self.soup("") + self.assertEqual( + soup.encode("latin1"), + b'\n') + + def test_large_xml_document(self): + """A large XML document should come out the same as it went in.""" + markup = (b'\n' + + b'0' * (2**12) + + b'') + soup = self.soup(markup) + self.assertEqual(soup.encode("utf-8"), markup) + + + def test_tags_are_empty_element_if_and_only_if_they_are_empty(self): + self.assertSoupEquals("

", "

") + self.assertSoupEquals("

foo

") + + def test_namespaces_are_preserved(self): + markup = 'This tag is in the a namespaceThis tag is in the b namespace' + soup = self.soup(markup) + root = soup.root + self.assertEqual("http://example.com/", root['xmlns:a']) + self.assertEqual("http://example.net/", root['xmlns:b']) + + def test_closing_namespaced_tag(self): + markup = '

20010504

' + soup = self.soup(markup) + self.assertEqual(str(soup.p), markup) + + def test_namespaced_attributes(self): + markup = '' + soup = self.soup(markup) + self.assertEqual(str(soup.foo), markup) + + def test_namespaced_attributes_xml_namespace(self): + markup = 'bar' + soup = self.soup(markup) + self.assertEqual(str(soup.foo), markup) + + def test_find_by_prefixed_name(self): + doc = """ +foo + bar + baz + +""" + soup = self.soup(doc) + + # There are three tags. + self.assertEqual(3, len(soup.find_all('tag'))) + + # But two of them are ns1:tag and one of them is ns2:tag. + self.assertEqual(2, len(soup.find_all('ns1:tag'))) + self.assertEqual(1, len(soup.find_all('ns2:tag'))) + + self.assertEqual(1, len(soup.find_all('ns2:tag', key='value'))) + self.assertEqual(3, len(soup.find_all(['ns1:tag', 'ns2:tag']))) + + def test_copy_tag_preserves_namespace(self): + xml = """ +""" + + soup = self.soup(xml) + tag = soup.document + duplicate = copy.copy(tag) + + # The two tags have the same namespace prefix. + self.assertEqual(tag.prefix, duplicate.prefix) + + def test_worst_case(self): + """Test the worst case (currently) for linking issues.""" + + soup = self.soup(BAD_DOCUMENT) + self.linkage_validator(soup) + + +class HTML5TreeBuilderSmokeTest(HTMLTreeBuilderSmokeTest): + """Smoke test for a tree builder that supports HTML5.""" + + def test_real_xhtml_document(self): + # Since XHTML is not HTML5, HTML5 parsers are not tested to handle + # XHTML documents in any particular way. + pass + + def test_html_tags_have_namespace(self): + markup = "" + soup = self.soup(markup) + self.assertEqual("http://www.w3.org/1999/xhtml", soup.a.namespace) + + def test_svg_tags_have_namespace(self): + markup = '' + soup = self.soup(markup) + namespace = "http://www.w3.org/2000/svg" + self.assertEqual(namespace, soup.svg.namespace) + self.assertEqual(namespace, soup.circle.namespace) + + + def test_mathml_tags_have_namespace(self): + markup = '5' + soup = self.soup(markup) + namespace = 'http://www.w3.org/1998/Math/MathML' + self.assertEqual(namespace, soup.math.namespace) + self.assertEqual(namespace, soup.msqrt.namespace) + + def test_xml_declaration_becomes_comment(self): + markup = '' + soup = self.soup(markup) + self.assertTrue(isinstance(soup.contents[0], Comment)) + self.assertEqual(soup.contents[0], '?xml version="1.0" encoding="utf-8"?') + self.assertEqual("html", soup.contents[0].next_element.name) + +def skipIf(condition, reason): + def nothing(test, *args, **kwargs): + return None + + def decorator(test_item): + if condition: + return nothing + else: + return test_item + + return decorator diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__init__.py new file mode 100644 index 00000000..ece0e405 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__init__.py @@ -0,0 +1,1274 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""BSON (Binary JSON) encoding and decoding. + +The mapping from Python types to BSON types is as follows: + +======================================= ============= =================== +Python Type BSON Type Supported Direction +======================================= ============= =================== +None null both +bool boolean both +int [#int]_ int32 / int64 py -> bson +long int64 py -> bson +`bson.int64.Int64` int64 both +float number (real) both +string string py -> bson +unicode string both +list array both +dict / `SON` object both +datetime.datetime [#dt]_ [#dt2]_ date both +`bson.regex.Regex` regex both +compiled re [#re]_ regex py -> bson +`bson.binary.Binary` binary both +`bson.objectid.ObjectId` oid both +`bson.dbref.DBRef` dbref both +None undefined bson -> py +unicode code bson -> py +`bson.code.Code` code py -> bson +unicode symbol bson -> py +bytes (Python 3) [#bytes]_ binary both +======================================= ============= =================== + +Note that, when using Python 2.x, to save binary data it must be wrapped as +an instance of `bson.binary.Binary`. Otherwise it will be saved as a BSON +string and retrieved as unicode. Users of Python 3.x can use the Python bytes +type. + +.. [#int] A Python int will be saved as a BSON int32 or BSON int64 depending + on its size. A BSON int32 will always decode to a Python int. A BSON + int64 will always decode to a :class:`~bson.int64.Int64`. +.. [#dt] datetime.datetime instances will be rounded to the nearest + millisecond when saved +.. [#dt2] all datetime.datetime instances are treated as *naive*. clients + should always use UTC. +.. [#re] :class:`~bson.regex.Regex` instances and regular expression + objects from ``re.compile()`` are both saved as BSON regular expressions. + BSON regular expressions are decoded as :class:`~bson.regex.Regex` + instances. +.. [#bytes] The bytes type from Python 3.x is encoded as BSON binary with + subtype 0. In Python 3.x it will be decoded back to bytes. In Python 2.x + it will be decoded to an instance of :class:`~bson.binary.Binary` with + subtype 0. +""" + +import calendar +import datetime +import itertools +import platform +import re +import struct +import sys +import uuid + +from codecs import (utf_8_decode as _utf_8_decode, + utf_8_encode as _utf_8_encode) + +from bson.binary import (Binary, UuidRepresentation, ALL_UUID_SUBTYPES, + OLD_UUID_SUBTYPE, + JAVA_LEGACY, CSHARP_LEGACY, + UUIDLegacy, UUID_SUBTYPE) +from bson.code import Code +from bson.codec_options import ( + CodecOptions, DEFAULT_CODEC_OPTIONS, _raw_document_class) +from bson.dbref import DBRef +from bson.decimal128 import Decimal128 +from bson.errors import (InvalidBSON, + InvalidDocument, + InvalidStringData) +from bson.int64 import Int64 +from bson.max_key import MaxKey +from bson.min_key import MinKey +from bson.objectid import ObjectId +from bson.py3compat import (abc, + b, + PY3, + iteritems, + text_type, + string_type, + reraise) +from bson.regex import Regex +from bson.son import SON, RE_TYPE +from bson.timestamp import Timestamp +from bson.tz_util import utc + + +try: + from bson import _cbson + _USE_C = True +except ImportError: + _USE_C = False + + +EPOCH_AWARE = datetime.datetime.fromtimestamp(0, utc) +EPOCH_NAIVE = datetime.datetime.utcfromtimestamp(0) + + +BSONNUM = b"\x01" # Floating point +BSONSTR = b"\x02" # UTF-8 string +BSONOBJ = b"\x03" # Embedded document +BSONARR = b"\x04" # Array +BSONBIN = b"\x05" # Binary +BSONUND = b"\x06" # Undefined +BSONOID = b"\x07" # ObjectId +BSONBOO = b"\x08" # Boolean +BSONDAT = b"\x09" # UTC Datetime +BSONNUL = b"\x0A" # Null +BSONRGX = b"\x0B" # Regex +BSONREF = b"\x0C" # DBRef +BSONCOD = b"\x0D" # Javascript code +BSONSYM = b"\x0E" # Symbol +BSONCWS = b"\x0F" # Javascript code with scope +BSONINT = b"\x10" # 32bit int +BSONTIM = b"\x11" # Timestamp +BSONLON = b"\x12" # 64bit int +BSONDEC = b"\x13" # Decimal128 +BSONMIN = b"\xFF" # Min key +BSONMAX = b"\x7F" # Max key + + +_UNPACK_FLOAT_FROM = struct.Struct("= obj_end: + raise InvalidBSON("invalid object length") + # If this is the top-level document, validate the total size too. + if position == 0 and obj_size != obj_end: + raise InvalidBSON("invalid object length") + return obj_size, end + + +def _get_object(data, view, position, obj_end, opts, dummy): + """Decode a BSON subdocument to opts.document_class or bson.dbref.DBRef.""" + obj_size, end = _get_object_size(data, position, obj_end) + if _raw_document_class(opts.document_class): + return (opts.document_class(data[position:end + 1], opts), + position + obj_size) + + obj = _elements_to_dict(data, view, position + 4, end, opts) + + position += obj_size + if "$ref" in obj: + return (DBRef(obj.pop("$ref"), obj.pop("$id", None), + obj.pop("$db", None), obj), position) + return obj, position + + +def _get_array(data, view, position, obj_end, opts, element_name): + """Decode a BSON array to python list.""" + size = _UNPACK_INT_FROM(data, position)[0] + end = position + size - 1 + if data[end] != _OBJEND: + raise InvalidBSON("bad eoo") + + position += 4 + end -= 1 + result = [] + + # Avoid doing global and attribute lookups in the loop. + append = result.append + index = data.index + getter = _ELEMENT_GETTER + decoder_map = opts.type_registry._decoder_map + + while position < end: + element_type = data[position] + # Just skip the keys. + position = index(b'\x00', position) + 1 + try: + value, position = getter[element_type]( + data, view, position, obj_end, opts, element_name) + except KeyError: + _raise_unknown_type(element_type, element_name) + + if decoder_map: + custom_decoder = decoder_map.get(type(value)) + if custom_decoder is not None: + value = custom_decoder(value) + + append(value) + + if position != end + 1: + raise InvalidBSON('bad array length') + return result, position + 1 + + +def _get_binary(data, view, position, obj_end, opts, dummy1): + """Decode a BSON binary to bson.binary.Binary or python UUID.""" + length, subtype = _UNPACK_LENGTH_SUBTYPE_FROM(data, position) + position += 5 + if subtype == 2: + length2 = _UNPACK_INT_FROM(data, position)[0] + position += 4 + if length2 != length - 4: + raise InvalidBSON("invalid binary (st 2) - lengths don't match!") + length = length2 + end = position + length + if length < 0 or end > obj_end: + raise InvalidBSON('bad binary object length') + + # Convert UUID subtypes to native UUIDs. + # TODO: PYTHON-2245 Decoding should follow UUID spec in PyMongo 4.0+ + if subtype in ALL_UUID_SUBTYPES: + uuid_representation = opts.uuid_representation + binary_value = Binary(data[position:end], subtype) + if uuid_representation == UuidRepresentation.UNSPECIFIED: + return binary_value, end + if subtype == UUID_SUBTYPE: + # Legacy behavior: use STANDARD with binary subtype 4. + uuid_representation = UuidRepresentation.STANDARD + elif uuid_representation == UuidRepresentation.STANDARD: + # subtype == OLD_UUID_SUBTYPE + # Legacy behavior: STANDARD is the same as PYTHON_LEGACY. + uuid_representation = UuidRepresentation.PYTHON_LEGACY + return binary_value.as_uuid(uuid_representation), end + + # Python3 special case. Decode subtype 0 to 'bytes'. + if PY3 and subtype == 0: + value = data[position:end] + else: + value = Binary(data[position:end], subtype) + + return value, end + + +def _get_oid(data, view, position, dummy0, dummy1, dummy2): + """Decode a BSON ObjectId to bson.objectid.ObjectId.""" + end = position + 12 + return ObjectId(data[position:end]), end + + +def _get_boolean(data, view, position, dummy0, dummy1, dummy2): + """Decode a BSON true/false to python True/False.""" + end = position + 1 + boolean_byte = data[position:end] + if boolean_byte == b'\x00': + return False, end + elif boolean_byte == b'\x01': + return True, end + raise InvalidBSON('invalid boolean value: %r' % boolean_byte) + + +def _get_date(data, view, position, dummy0, opts, dummy1): + """Decode a BSON datetime to python datetime.datetime.""" + return _millis_to_datetime( + _UNPACK_LONG_FROM(data, position)[0], opts), position + 8 + + +def _get_code(data, view, position, obj_end, opts, element_name): + """Decode a BSON code to bson.code.Code.""" + code, position = _get_string(data, view, position, obj_end, opts, element_name) + return Code(code), position + + +def _get_code_w_scope(data, view, position, obj_end, opts, element_name): + """Decode a BSON code_w_scope to bson.code.Code.""" + code_end = position + _UNPACK_INT_FROM(data, position)[0] + code, position = _get_string( + data, view, position + 4, code_end, opts, element_name) + scope, position = _get_object(data, view, position, code_end, opts, element_name) + if position != code_end: + raise InvalidBSON('scope outside of javascript code boundaries') + return Code(code, scope), position + + +def _get_regex(data, view, position, dummy0, opts, dummy1): + """Decode a BSON regex to bson.regex.Regex or a python pattern object.""" + pattern, position = _get_c_string(data, view, position, opts) + bson_flags, position = _get_c_string(data, view, position, opts) + bson_re = Regex(pattern, bson_flags) + return bson_re, position + + +def _get_ref(data, view, position, obj_end, opts, element_name): + """Decode (deprecated) BSON DBPointer to bson.dbref.DBRef.""" + collection, position = _get_string( + data, view, position, obj_end, opts, element_name) + oid, position = _get_oid(data, view, position, obj_end, opts, element_name) + return DBRef(collection, oid), position + + +def _get_timestamp(data, view, position, dummy0, dummy1, dummy2): + """Decode a BSON timestamp to bson.timestamp.Timestamp.""" + inc, timestamp = _UNPACK_TIMESTAMP_FROM(data, position) + return Timestamp(timestamp, inc), position + 8 + + +def _get_int64(data, view, position, dummy0, dummy1, dummy2): + """Decode a BSON int64 to bson.int64.Int64.""" + return Int64(_UNPACK_LONG_FROM(data, position)[0]), position + 8 + + +def _get_decimal128(data, view, position, dummy0, dummy1, dummy2): + """Decode a BSON decimal128 to bson.decimal128.Decimal128.""" + end = position + 16 + return Decimal128.from_bid(data[position:end]), end + + +# Each decoder function's signature is: +# - data: bytes +# - view: memoryview that references `data` +# - position: int, beginning of object in 'data' to decode +# - obj_end: int, end of object to decode in 'data' if variable-length type +# - opts: a CodecOptions +_ELEMENT_GETTER = { + _maybe_ord(BSONNUM): _get_float, + _maybe_ord(BSONSTR): _get_string, + _maybe_ord(BSONOBJ): _get_object, + _maybe_ord(BSONARR): _get_array, + _maybe_ord(BSONBIN): _get_binary, + _maybe_ord(BSONUND): lambda u, v, w, x, y, z: (None, w), # Deprecated undefined + _maybe_ord(BSONOID): _get_oid, + _maybe_ord(BSONBOO): _get_boolean, + _maybe_ord(BSONDAT): _get_date, + _maybe_ord(BSONNUL): lambda u, v, w, x, y, z: (None, w), + _maybe_ord(BSONRGX): _get_regex, + _maybe_ord(BSONREF): _get_ref, # Deprecated DBPointer + _maybe_ord(BSONCOD): _get_code, + _maybe_ord(BSONSYM): _get_string, # Deprecated symbol + _maybe_ord(BSONCWS): _get_code_w_scope, + _maybe_ord(BSONINT): _get_int, + _maybe_ord(BSONTIM): _get_timestamp, + _maybe_ord(BSONLON): _get_int64, + _maybe_ord(BSONDEC): _get_decimal128, + _maybe_ord(BSONMIN): lambda u, v, w, x, y, z: (MinKey(), w), + _maybe_ord(BSONMAX): lambda u, v, w, x, y, z: (MaxKey(), w)} + + +if _USE_C: + def _element_to_dict(data, view, position, obj_end, opts): + return _cbson._element_to_dict(data, position, obj_end, opts) +else: + def _element_to_dict(data, view, position, obj_end, opts): + """Decode a single key, value pair.""" + element_type = data[position] + position += 1 + element_name, position = _get_c_string(data, view, position, opts) + try: + value, position = _ELEMENT_GETTER[element_type](data, view, position, + obj_end, opts, + element_name) + except KeyError: + _raise_unknown_type(element_type, element_name) + + if opts.type_registry._decoder_map: + custom_decoder = opts.type_registry._decoder_map.get(type(value)) + if custom_decoder is not None: + value = custom_decoder(value) + + return element_name, value, position + + +def _raw_to_dict(data, position, obj_end, opts, result): + data, view = get_data_and_view(data) + return _elements_to_dict(data, view, position, obj_end, opts, result) + + +def _elements_to_dict(data, view, position, obj_end, opts, result=None): + """Decode a BSON document into result.""" + if result is None: + result = opts.document_class() + end = obj_end - 1 + while position < end: + key, value, position = _element_to_dict(data, view, position, obj_end, opts) + result[key] = value + if position != obj_end: + raise InvalidBSON('bad object or element length') + return result + + +def _bson_to_dict(data, opts): + """Decode a BSON string to document_class.""" + data, view = get_data_and_view(data) + try: + if _raw_document_class(opts.document_class): + return opts.document_class(data, opts) + _, end = _get_object_size(data, 0, len(data)) + return _elements_to_dict(data, view, 4, end, opts) + except InvalidBSON: + raise + except Exception: + # Change exception type to InvalidBSON but preserve traceback. + _, exc_value, exc_tb = sys.exc_info() + reraise(InvalidBSON, exc_value, exc_tb) +if _USE_C: + _bson_to_dict = _cbson._bson_to_dict + + +_PACK_FLOAT = struct.Struct(">> import collections # From Python standard library. + >>> import bson + >>> from bson.codec_options import CodecOptions + >>> data = bson.encode({'a': 1}) + >>> decoded_doc = bson.decode(data) + + >>> options = CodecOptions(document_class=collections.OrderedDict) + >>> decoded_doc = bson.decode(data, codec_options=options) + >>> type(decoded_doc) + + + :Parameters: + - `data`: the BSON to decode. Any bytes-like object that implements + the buffer protocol. + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionadded:: 3.9 + """ + if not isinstance(codec_options, CodecOptions): + raise _CODEC_OPTIONS_TYPE_ERROR + + return _bson_to_dict(data, codec_options) + + +def decode_all(data, codec_options=DEFAULT_CODEC_OPTIONS): + """Decode BSON data to multiple documents. + + `data` must be a bytes-like object implementing the buffer protocol that + provides concatenated, valid, BSON-encoded documents. + + :Parameters: + - `data`: BSON data + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionchanged:: 3.9 + Supports bytes-like objects that implement the buffer protocol. + + .. versionchanged:: 3.0 + Removed `compile_re` option: PyMongo now always represents BSON regular + expressions as :class:`~bson.regex.Regex` objects. Use + :meth:`~bson.regex.Regex.try_compile` to attempt to convert from a + BSON regular expression to a Python regular expression object. + + Replaced `as_class`, `tz_aware`, and `uuid_subtype` options with + `codec_options`. + + .. versionchanged:: 2.7 + Added `compile_re` option. If set to False, PyMongo represented BSON + regular expressions as :class:`~bson.regex.Regex` objects instead of + attempting to compile BSON regular expressions as Python native + regular expressions, thus preventing errors for some incompatible + patterns, see `PYTHON-500`_. + + .. _PYTHON-500: https://jira.mongodb.org/browse/PYTHON-500 + """ + data, view = get_data_and_view(data) + if not isinstance(codec_options, CodecOptions): + raise _CODEC_OPTIONS_TYPE_ERROR + + data_len = len(data) + docs = [] + position = 0 + end = data_len - 1 + use_raw = _raw_document_class(codec_options.document_class) + try: + while position < end: + obj_size = _UNPACK_INT_FROM(data, position)[0] + if data_len - position < obj_size: + raise InvalidBSON("invalid object size") + obj_end = position + obj_size - 1 + if data[obj_end] != _OBJEND: + raise InvalidBSON("bad eoo") + if use_raw: + docs.append( + codec_options.document_class( + data[position:obj_end + 1], codec_options)) + else: + docs.append(_elements_to_dict(data, + view, + position + 4, + obj_end, + codec_options)) + position += obj_size + return docs + except InvalidBSON: + raise + except Exception: + # Change exception type to InvalidBSON but preserve traceback. + _, exc_value, exc_tb = sys.exc_info() + reraise(InvalidBSON, exc_value, exc_tb) + + +if _USE_C: + decode_all = _cbson.decode_all + + +def _decode_selective(rawdoc, fields, codec_options): + if _raw_document_class(codec_options.document_class): + # If document_class is RawBSONDocument, use vanilla dictionary for + # decoding command response. + doc = {} + else: + # Else, use the specified document_class. + doc = codec_options.document_class() + for key, value in iteritems(rawdoc): + if key in fields: + if fields[key] == 1: + doc[key] = _bson_to_dict(rawdoc.raw, codec_options)[key] + else: + doc[key] = _decode_selective(value, fields[key], codec_options) + else: + doc[key] = value + return doc + + +def _convert_raw_document_lists_to_streams(document): + cursor = document.get('cursor') + if cursor: + for key in ('firstBatch', 'nextBatch'): + batch = cursor.get(key) + if batch: + stream = b"".join(doc.raw for doc in batch) + cursor[key] = [stream] + + +def _decode_all_selective(data, codec_options, fields): + """Decode BSON data to a single document while using user-provided + custom decoding logic. + + `data` must be a string representing a valid, BSON-encoded document. + + :Parameters: + - `data`: BSON data + - `codec_options`: An instance of + :class:`~bson.codec_options.CodecOptions` with user-specified type + decoders. If no decoders are found, this method is the same as + ``decode_all``. + - `fields`: Map of document namespaces where data that needs + to be custom decoded lives or None. For example, to custom decode a + list of objects in 'field1.subfield1', the specified value should be + ``{'field1': {'subfield1': 1}}``. If ``fields`` is an empty map or + None, this method is the same as ``decode_all``. + + :Returns: + - `document_list`: Single-member list containing the decoded document. + + .. versionadded:: 3.8 + """ + if not codec_options.type_registry._decoder_map: + return decode_all(data, codec_options) + + if not fields: + return decode_all(data, codec_options.with_options(type_registry=None)) + + # Decode documents for internal use. + from bson.raw_bson import RawBSONDocument + internal_codec_options = codec_options.with_options( + document_class=RawBSONDocument, type_registry=None) + _doc = _bson_to_dict(data, internal_codec_options) + return [_decode_selective(_doc, fields, codec_options,)] + + +def decode_iter(data, codec_options=DEFAULT_CODEC_OPTIONS): + """Decode BSON data to multiple documents as a generator. + + Works similarly to the decode_all function, but yields one document at a + time. + + `data` must be a string of concatenated, valid, BSON-encoded + documents. + + :Parameters: + - `data`: BSON data + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionchanged:: 3.0 + Replaced `as_class`, `tz_aware`, and `uuid_subtype` options with + `codec_options`. + + .. versionadded:: 2.8 + """ + if not isinstance(codec_options, CodecOptions): + raise _CODEC_OPTIONS_TYPE_ERROR + + position = 0 + end = len(data) - 1 + while position < end: + obj_size = _UNPACK_INT_FROM(data, position)[0] + elements = data[position:position + obj_size] + position += obj_size + + yield _bson_to_dict(elements, codec_options) + + +def decode_file_iter(file_obj, codec_options=DEFAULT_CODEC_OPTIONS): + """Decode bson data from a file to multiple documents as a generator. + + Works similarly to the decode_all function, but reads from the file object + in chunks and parses bson in chunks, yielding one document at a time. + + :Parameters: + - `file_obj`: A file object containing BSON data. + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionchanged:: 3.0 + Replaced `as_class`, `tz_aware`, and `uuid_subtype` options with + `codec_options`. + + .. versionadded:: 2.8 + """ + while True: + # Read size of next object. + size_data = file_obj.read(4) + if not size_data: + break # Finished with file normaly. + elif len(size_data) != 4: + raise InvalidBSON("cut off in middle of objsize") + obj_size = _UNPACK_INT_FROM(size_data, 0)[0] - 4 + elements = size_data + file_obj.read(max(0, obj_size)) + yield _bson_to_dict(elements, codec_options) + + +def is_valid(bson): + """Check that the given string represents valid :class:`BSON` data. + + Raises :class:`TypeError` if `bson` is not an instance of + :class:`str` (:class:`bytes` in python 3). Returns ``True`` + if `bson` is valid :class:`BSON`, ``False`` otherwise. + + :Parameters: + - `bson`: the data to be validated + """ + if not isinstance(bson, bytes): + raise TypeError("BSON data must be an instance of a subclass of bytes") + + try: + _bson_to_dict(bson, DEFAULT_CODEC_OPTIONS) + return True + except Exception: + return False + + +class BSON(bytes): + """BSON (Binary JSON) data. + + .. warning:: Using this class to encode and decode BSON adds a performance + cost. For better performance use the module level functions + :func:`encode` and :func:`decode` instead. + """ + + @classmethod + def encode(cls, document, check_keys=False, + codec_options=DEFAULT_CODEC_OPTIONS): + """Encode a document to a new :class:`BSON` instance. + + A document can be any mapping type (like :class:`dict`). + + Raises :class:`TypeError` if `document` is not a mapping type, + or contains keys that are not instances of + :class:`basestring` (:class:`str` in python 3). Raises + :class:`~bson.errors.InvalidDocument` if `document` cannot be + converted to :class:`BSON`. + + :Parameters: + - `document`: mapping type representing a document + - `check_keys` (optional): check if keys start with '$' or + contain '.', raising :class:`~bson.errors.InvalidDocument` in + either case + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionchanged:: 3.0 + Replaced `uuid_subtype` option with `codec_options`. + """ + return cls(encode(document, check_keys, codec_options)) + + def decode(self, codec_options=DEFAULT_CODEC_OPTIONS): + """Decode this BSON data. + + By default, returns a BSON document represented as a Python + :class:`dict`. To use a different :class:`MutableMapping` class, + configure a :class:`~bson.codec_options.CodecOptions`:: + + >>> import collections # From Python standard library. + >>> import bson + >>> from bson.codec_options import CodecOptions + >>> data = bson.BSON.encode({'a': 1}) + >>> decoded_doc = bson.BSON(data).decode() + + >>> options = CodecOptions(document_class=collections.OrderedDict) + >>> decoded_doc = bson.BSON(data).decode(codec_options=options) + >>> type(decoded_doc) + + + :Parameters: + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions`. + + .. versionchanged:: 3.0 + Removed `compile_re` option: PyMongo now always represents BSON + regular expressions as :class:`~bson.regex.Regex` objects. Use + :meth:`~bson.regex.Regex.try_compile` to attempt to convert from a + BSON regular expression to a Python regular expression object. + + Replaced `as_class`, `tz_aware`, and `uuid_subtype` options with + `codec_options`. + + .. versionchanged:: 2.7 + Added `compile_re` option. If set to False, PyMongo represented BSON + regular expressions as :class:`~bson.regex.Regex` objects instead of + attempting to compile BSON regular expressions as Python native + regular expressions, thus preventing errors for some incompatible + patterns, see `PYTHON-500`_. + + .. _PYTHON-500: https://jira.mongodb.org/browse/PYTHON-500 + """ + return decode(self, codec_options) + + +def has_c(): + """Is the C extension installed? + """ + return _USE_C diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..24db92c9ff3bf4fbde4318597f0ab54633afb9cc GIT binary patch literal 36366 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/binary.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/binary.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d101725db93d30290a7d6203e9649795ea8dc144 GIT binary patch literal 9989 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/code.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/code.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..98a2ff5ec966a10f3b6b468795cdefedbd8936fe GIT binary patch literal 2891 zcmZ`*O>Y}T7~U^Cj^m^Vl~QQc4oHQ#YE4Br6bqr2LJ?n~YAQiZr1f}b9B;DTb!Wy2 zHtvP?z>U9;k%~u#MVXK+PT410-)^?*&!ER?2D#6BQNE&$ z!tT&aMl$#B+~3HTjr`Hr_lPzwK0aPS6`|%fj!}MMJD&ydr!Ua4HXO0UrMqJP^Kj^$W-eTdQ7Yc<%C8 zOU>F*!nJO9?_uRLr83oJai4X`PK-25GsAcaleOV#Bw5zCr{~9d973$!UA8`-#01W! zY&0>0EM*%_21dI&%0{wlPnUAL-OVhO-7YPk)Nuq$#F6Qih_^@p+vh6gy#&xBoasrX zrD44Z8^H{67H4!O&Qh)>jB92F@`P@#cE&?EmXzYy*dE%GlY>kNHeb{&_C+6}=E{f( z(gS(iTJZb<78`aDCke~;rBX41gr^faVgraG$_%(!ke6C93*Z)Dm-e>raK(qxNTu6$ zH)B^z&$QW1R?v=!Obw6Im&K{ch#$GnlQB0^6f|ehsY-Ed(XWhx2X?2HvVOnS6#7PUU!e>K18W9_Pl?@p@fgJ9~;E=8JW1t0jy2-#1@gw2!Pi3Ev z69bbnHV@4fy9fKo{g9f(Ad&Zp7kKvwPXQC*mqoGV`5-m}0NIK6Wjd#e_YfHiR9wEi zcYtWqNSg&V3Q_Z@D?*$n+WL_Kob(?X@q7@%hI<24Erc=J3B08*fLoM^${=gC7$R09 zU!nm|ccf^y*+%Pw(m04?qM)Uq$ri^G?j>&KY}s&<9Fc}F>HhSvJ5SwbDA&$r3gu8uyW>&l*%h%rQ1^azO`zL$t@6lIZBsp5nqlW*O?Xe-C*H## zZOrHBZQ7W*yUVj6tbgaEX9LHqOmxG7$`h4?6S;Ot z=fT+YuTS49T>d}XsFb0u*JD(vq5v!6Fke0@*Lf`rQ&fpCRCN6*qBZvs-uV(1O_>R=uJ)NcRk*L;a zq9`&p(DW5_j$3yFH~6>eueqnahUd8r`gt|eo0?pmsGRqs|NOxtLeK0 zJwZ`#Qb)Wm06B-(@6ie%?sT=}s5lo{cvz-~#z$B#<7J+J>K(#j{29`(?;)LN?9zD8 z+X7;X@OCp$%Q&Qn-U1I{eCk<#@`}A?oHp zMc;mu`Fmc&`f{_7ejd{=(UT&=d!)yje5`}!o9*zu>|lS9`eHDO~f~Na0gNnTd70BGT0byAXy0t_SeYMVdQyjvd)hA--Ni z)32hdxxu->t6%iodZp&qDuHMD+-%m=+gR?bQK}$IHgMODxUt!3E5LEG+t4Vy@Dg=- S?W4lJk10eo`8)8>`u_o8W&_p$ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/codec_options.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/codec_options.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f549c863d7a338a2bb6843b8de62ab903efb2f45 GIT binary patch literal 12394 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 Jw6|E(`7c&KK@0!@ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/decimal128.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/decimal128.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9e22523672084fa0fff50fd98031a1b4113bf267 GIT binary patch literal 9722 zcmc&)$#)#bd9Pk(!C6Z)tgxqtB|AM~e5}a~~FOl=Y{J!e$*$9fV{gU*&uIjF> zzxwLi>Q`eA4CEND-+kM#|7nu3f2Ehss}C>NaQmNWj0sj|LKAvbD{Cs(%eu;qvVq*F znmeg-dM8uPYRpN?t4`lmuH5g9sW$m?-syAlTLbI5Fh%NXt=#YEPXMpk%nGkH4pwTls?XPJl0T}+ZP(l2kKACB z2b&JRv3$40g;Q~N?CSJ|t324NJH=eCSma+g(syf~ErcUxXZcL=qAK=kfrHl-^j&Co zQ^QbSE}e(Fu5^5Ur{-o2a}{ zd|W&n#z@at!3+cYRN$&`c%YUKO+VH>$fERp)+v z?+eHKVy5`x`?uY-`@S1E=j(Q5+um^e`)hv9d#}yCVtp^{x7u`!(=2o(OqZkz4SnvX zRr*MBrJ2je7*>@M?cbh1Kcp_5O|E6SURS$c>)o#`%MPJRtdI%Kx^yaGR@Qbs0ZxbJ z;*RT4YCjIM6}#>RcGVA4>s5OLSs?AYU(mu-rE2fgYPFw1wlF&*y4Ngm>mWSgZ zU{AECY@cngCiG>F1^SjjQrc7!sut{*pE$v;^n7k(;XFUEy^2FiHjCkXe|9xyU-4$m z3!KNnD!1!(S*uIe4xAjv^@7|kEiNvezjEm!hrpg+bAv>F`FgbmiGX<5YgkyW*4i(s zLF92z3jxSmH&;Hh?%rEjx?5Tf%}NbRmWfFSGcgU|gjuTxep?_U*{bk#MLM9$YOlCe ziKt#iwVy`9%&eBx;`N z42^li)69QoO4$MpRzL$+pO{aXyp24C{G%Yf%!14^m1m!_`^LV$Z|s|R>qG57G!5wm zIiVkDUuh`oN7=99o?iud^c+w?P%OKyH2KKpz$S^7gjBRC?+CPT!?HK4{H3z(gL5{bT>9RWXeCstF=e! zsQ`OOayWa>miCSlz%I_J0?yC#RV8Grvz*LQhjb@W9gnZtml_i#yA;`8;jHaKPVGI2 ztl+NCVOP1oTd&t-;E1qWc*um1+9@d`s2EP+LLGf?gHpsAKoRif+pm-I83`}_kGzlV~-m>fkG=G7>%lE5}DEZ)T6q=VsLw=#wOt`Bp(?s~AW zVIN+6cf$iKQdViHbPL%%%Cfd^1-mf+VH!<5+Y57_l1X2bvL?d}b)&+xRa!1xFCo9D zatuPR7=$td)*&>vU?jpE*4nB%-bSz)rljp{IH5t7a?o1*?B3ndVrj*?v2=a8^Zm~C z<&QDa^3sQ;Lcb)X4~#kdqUZHA>g59ZciDCt(7=5Sw_iu%FhpXEqA)~Ydf604ITcxkGVFlJAmYe4&~(xF zHS9#W&&dgBrF!lcc`<k~)RFV~`T33*WHN3yIX+dKnwq*aUMR#`+8$tXBC4B6s(OZK zb^VijPR?Asa`DoIE7Q{#E=^yanYnWL^2Kxf(s$FKzVauTm0qVAPi^%ak0Ppb9FdRG z54hNP68vbZ#wkwWH(bw_dwdDLcf*khJNYDxVSzmFjvd724IJFD`k`W4jWpo{NcslD^R9F1!X}i${n}q{As#s)J@~DQy?3%Wa=K zk1I}{!co61pf8B%cyW5BI6a<7ALlF5t~hH5C;8+~%?}VgS70(YEN_(~JPHblry&P) z%dI+me9jLL(an#;LAjp8r_aIf@VT9u*sVJAttIEYSWH;NTi&jhAG7?g=TsQRClY={ zK9VB;i_W~CDL}pOp>aJ`E$H?;Xa{I-w`y+nDUhxcRU~ZrFMGQlkHXmio9)-ugY#U+C9N7 zal87+-t+mI12a-1eS|=h?TrWOP)Mk`8ZCC|5LgQC(PM2dZallb>s4k~yS+O({kY3& zuYO=RhoC2s(H7UqG{-`zdIyjB`~0P&PPUheI;#C`BGR2P$Yl4B1)3?GcU#S%Hl%Bv zvW@y;_lGByBG0s4Ot-qV`87!qU(4Gld(bt(|8+WBYT4#br(x)%bV_OP8%e6rtk!LIGp$sn|RkyQ2kJy`&LsQ7N=n@89JBVt&VB(Vk}KI=mn;9dx(In>eqU z{Usy#fAI+CUp++3*^g?E95_+9Uu>W@XIDEyhaxr{B67y7&|5gZ$fhVWqfC0l)?TyG z!LlB%c8u6z7P=dCY2i^r#r%E6SW&B24i@w26@x{sUO8C8^;e7*H*2ZKqgrc&>UZKV z?a8ll+7wcV0}Riua(A89z?E^37!%eTDmq@JMi3LCzoh4PELCI=`TOs83U!Z>T#>sG z@!7S~*H)5?Vk#BDx81o@vf(vLb0urGnFPTuR z#vPRO+WT7wO{2LKbRcRLZT!k9%R(@DNQhL0w)V-DZ1ZoTz!ykpdmjKL0;Z-P=yE(T zX}f=4Z!#-|JMGP@7MTDD2kJiw`lw!L+lE|dAwQk%2ZMfLG_`f@6n1Q1VRwgJmsvWb z4>vxKgG27S4Mzp!%IC!ZYg2{5{7Go#?)2uH}o-&fn#@R-#mC*o;1+*L$7Ym-O> zw5h-X16zDaz(m-$0?b*V1prA*->I&vEqw2$J8J=q05o9zJ1qtw(F}X*5sh}!Sz}Od z9B-3QOxkuKegyco5Wn95I%%>k2CR>5Y5O|XRR>arvjtBVK<)5uTw{T;t;?%{`6Sge zgdxmz zJTStC{~Y%k5_;V0EP83G*U-y)eZwApD~|7{<8~)#RG|Y=&PS&l!9XyGlF_}T4R@)md1(Ye=ObJ-1l|s!6wObt!|MM?3Cf|mz6g1Vaqw2rD%rN;Dst$)J zc}@w5;vs=fhtF{x5@K^mVy1vN0s0gK7dwN`2drLe0xto3Qphy^cvBr@ybP~t zlL>i$5hZGge%vm`o?@Jcoc0lz78Q5E<x0 zK%@aNa~GV>n-w zCj{g+fY(&=s{_GDP*yPH2AawuC1eH)2!W7=hHxsqnw+sHsIaUb6Gdb%8NuOD&&Egx zU2&r>+PWA^)>kN&9;he^EY(Ym;r0-d6L0$y1xa&|JCyWr1#yLR>LBD=i#6Sgo7BHx z707xk{tV-x8AWyAlcl0KX`%3$-eFjOdc?=`n4c5i2o`6U*3AwAM%xoWFw<`H0wY?B zL&v%Z`sH?;mrtLLRuiKrPmydlwJm)cGz3OWN5NF; zC>Mzw4@o#!ss&5QzXluuPAN%A)v&>ly=#Ox-FawPOGGBwVy5MwgpFfeOrjPq5ZPi6 zX>Sv&w5{i%b`f)wBs@aJ5#RH$Af*nrbbm|L7Dk|aIPuy+(=caQ5#ozy@Rqh~aSa4r z)G8?M!$MYTfp1ymyo#i)9b0Z=w#!5UX-?R$uwUAd*M!`rk}Ms)BSha*Y?E|8C?zEU zCA*aDQPQBKE!ygdA_T?qU*o~2@BxQX4@}+Ev-#{hx|SQnZDuoBL;X^!ZQ(un3+ks% z3)4{1-AaHX%ssz6NPn)tKPqO_rZkYm+p=ll?<0~_K`v23kxH103?lvWLq!5%b`7T* ze#LdeO#Ii5FufcNZPI@?WR<$5cRlsu(m<^!qdd?)`MY!dv#!^rQn}wkp|!B|;nK>o z6x6dq$r>dT%gA>rIY-G1B^N27gHm|`NjUV$-Jg{ftdFkWzGW?bx>yQ_dm;HSn}EDw zCI+tMN$QWkh%l)<3x#h{phLP4ZHdygwJoO-L?VC0!i3r6h=4*#zl_Ap(1Bo9A2xAx vNXLk&yb4(8=ny~H#waKM6W@l8GClsO+W*%7Go9BF0I8!!{e+S2%TE6f)+L+N literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/errors.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/errors.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..010fdc21760ae34abd954e665734ef9d38a6c6ef GIT binary patch literal 1224 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 D)Tl0^ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/objectid.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/objectid.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..a4757feb9932f5550bf70444aac42b72aa31984c GIT binary patch literal 9030 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/py3compat.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/py3compat.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..348110d427f2fcf62c3b7d49b98618b159191d7e GIT binary patch literal 2620 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/regex.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/regex.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..61ee63cf8934a01566f01b9fa2054a8d1ad4175b GIT binary patch literal 4063 zcmeHK-EQN?73PrCkL8~@+jg6zZ8~vb*a{qN0r#dtyU4Cr2n;y#!gc~wFhbGd$f8Y= z+L@7Usme{g57PE--=TMX3*PoBuaKMVcZQ;*wY^0zdRYn_l4oYloHO&C?;QE7s}&2^ z-+vtY|6I4Mf6>R{<>KQ@-0B6Iz-n0m3+#xs7@kgK_nnr*NajXvztAf5i>)HQ3qkR< z)hc~u1*M?;+6u~|eCxE90{hsiE{%V8k|dGh-9&OJ22v;y>o7j&UnlW-^5Qv!=flXC zT-;En3X@pXDnDR-t661f>8RnI{OM(*YNyLeOHB0iXdu!hEpD`V?JycUy=*+`-ovdl znt*)|7bez~B_B_iwl3JA1&L!M+eTs=iEAWvBXNwRU?c}d;u=ZONWL?Yf{~PrWMCvk zl1vz!E;l6^m9j8pQOf!$Qz;v!?50{uZ7I^q{#VVzqsHE|<3?IMINW=7&`6iQ{^sCh z|6sof(Tl^AX9ovq>6_;M-r8TvakXz_CJ@g;86L?bL<#%kFCYdL}4az!C<0{69b%UZ?Y!=M< z&eqHZ8t7q|*{d3P=*7Mcuf+CL#e)-S2I~Afqkih`9mT;J){P?3(O{4ojsVBD{pYQz z)~!12w7B`cI=8(3(wBZ;z;0DvQ1%7KmSSkT&Y#hwJLJTZvkNSe9gf-k+}&!sy>Q~S z8o%~s48p>02DSD2R9WMx)Q29f+g`sx^#k!(~vTesY}U6J|<~t z3N85vUr0|*Cjuv%B@H8I%};6Q@&e9l5U4dY*2fiQ<5zrZzjfX5hew8#7e<;K(s5|$ z^rH6}o3-(gv6;5JHW=+w?SRq1VmYHt*u?S*7-MU2nyl;6#J(k2Io>eRB}fk@$c~V# zW44Xi7?JT|;D7~Pe}GK(9$LsqcOFnDL?(u$4DTq>9Y%acH3Z`vVh_ZXK`@9`&RHsq z>A=7ape}wL>fSVXw$uaj5h6ZC{{l|lAK=rYLx^XfoMDD@gufvh^lc{tA`?HVA_f6T zjT4gmEYy8pT^hXm)A@NAF6iOB(*wVBh+cRUUJAYu_BTu!G|&Dfwr7cdHhVnd(>ZoC zLvxspH#0`O+fP9VL-S$HYDH2?mxP+Ma5mCH$&X3!2{pf z780UgJ$rQ&h6HK@~3#bO(<*ahp_kFi+QZjM)tncJIkhi}Si z)t>Ld8)m$|>n_fW3UJRGKx1yi?1ZweduGh&hRo2`U&#;<#)b1YDw3G*z?r?QV9AP! zyh<_FwK>X^|4=(E1nd9veP3P*nJ$~8MB9-B@>8;BgPJWgq!zVw53xai z4>F{>_(nujb%%YVpRfBFHLK@{XVWqXCKJLO0J29dxpoB#j- literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/son.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/son.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0175613537c353e00486c0cbaa20287b193de35a GIT binary patch literal 6393 zcma)A%WoUU9o`qo6)nk%?f4bj*(A1OIyU3jdA5#`#BtL!iJV4mg0MEWE6z$@i`=DW zmvTi=Ef5(zLhpO+DL{c9dds2d_s#5*B4q=mG&8$9kKc2C zuV8MjZs7Ozw}aq!2Myz&eA)SP@bVT~`U7;rXc@v3R>y3aYP4DwM!REootD$Bv?`_% zRzvGSO*q@;mf3ROGekvH?;D~T&TQGOy0DgvMs4u#8%fehy_H0IZ5akx6t8+gEWBPO*FOnYu|s+yYV%7VqcHW_ zLF_GuUO&a2C{D955MHw4;Ycr8z7w{y^qjZc&%8LvynDC9Siwo82xT41*20a{i}2s= zB{B=*tm(bIWADW2clv4Ob)vP<3vin31|9F?jqG+3*GC9#G`|7!jKzkP+re@>pNTS1 zl!e_iH`<)p`Lm0c^j~-g4KUgulUufUMcBf*Z?>E-jTKX|)ooQoO}O`sR#nW1I>wsV zBW5wWVouCsoDqA)0>-*{LhQr1N9-2|FwTl6#X*d7;*dCuab6q|M=|adPl;m~7sPRK z0^<`3*3-hf@3!`dSH&~pSzxeVJSR?K_JBAgPGfvhye6I(XE1Y6ye=BzES?UD7sNTt z9Tw+B6XOx_qPT$ZsCY?S#Q2oBBwogN>`TKjTF0RlZ{#-QGx!IEB!Vn}Y(4zm_R{`x zyAz}-B}k@1SV0C|iQ)_mpD8!0P$@d9Qcou9k$@@$>Xeo6o)`W+lMqtW4m0WqwNHdl zEbP1&Ww$BerV{gbZ|uGO@%!q4H0nlFvn=u2Nv8u9g0iK}>x3POcZt@DOuB{ey^GD) zUTCU~i*0L%d?{YG575#x=vIxP;TxIxz#1Ccrir%)_Rt(XS$q=4lJU@7Y&dz{2a>)| z12bwuKElcha!4f_X48uddw-zA5u-25p0 zZE~vk(PXggMN=eZAa7`FS$9Cbi zl(K@iyyp9Hc+dA`P0!iw4k#x@a*p#ZZ+8&4!-r-*XZxtT}4Y@Mz?Bg0`)t_yT+}fo7T{L0J}E?8AI!cv0@!m61xklCTz$L zQacDqHJrtPd*+lp=be&`!3w~K@#-ip z7F3RN*0!yct&oJmRUX1dNr?F#-%oLOV7Yw1Kw2KNqh}*wJfd#1C$+)LbifI#HS_u01q0TqVJ=7#-f+cd$2AM!_7oo-nfE6bSv51KJJL6kMR&C8vn9dyzwcqkXj^E~KLlBnuU0p?3N)W>H{ z&{2|3dKBp@q$2t5SCGY{NT+0JxA$|)VRVZ01*+y(g=+31-;yt3p|*2ljFk(#h>4Js zm(UH47h>wBk0e>KZG3=w;wgDWX|lj$Nikg;b^H01Cx34nO!j;l z#>mE^^$?|rs1qXJoY%yiBDFE#$_uAuSjK!!UrXG<2K7s zsh7#9y%s@HQ2K~HRdYH^S)FM%n~k$5b+rT3y1WP#tuPc=pWxdLMQQhC3WXZ0!YEn?MPk^Gl zMxe$~-KGj`w#>(cHH_$x;qOHOCr(kg>G~=F(`qyda{h`{I>>pQPNdN1ahNl;dpt1? z`6iI1sA-xNUzj4OIP5?Xf)Zu;=@n}i(zcGp#@3K_eG1pV;gbqus#f*8Mpd%DDxYCT z7Ui{%P$58NN@cV7-!n#EoZpg}l1TLl`dx02en}ZH41C9g3%f}aCR3)F1Qnl@;(k2%WBF-%=&)0-S_{F z-6|Jh8O+6B9c@85F{HE$WcSYH4b<#L|0h_(iGwbz7|M8lHxc~~p8?=*Kj;)QFiEf$ zDE7<%lqz1yr}#welPp*$pRDN8dEyKFMn#q9*j-@vGCSIINna(u&+aXD6pr%6nqfcW z>-+3@=_REtm(b;NMJ25rb~P4Pv=<4QFsYY$D8$z0Q^)vL1=x9V10$F*G-efej* z_N-H{xpS^tU#M3xhcE7aCA`KS`56w;a1FCNDDrYAL*SX$_#IAB jUgtKYxWr_KyHa=(#oWEDnS6zBDk68P5Sq16nYaH3Z2u6= literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/timestamp.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/__pycache__/timestamp.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..77780605b2d7259ef6bce82792b1e57511978d21 GIT binary patch literal 3874 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 + to use + + .. versionchanged:: 3.9 + Support any bytes-like type that implements the buffer protocol. + """ + + _type_marker = 5 + + def __new__(cls, data, subtype=BINARY_SUBTYPE): + if not isinstance(subtype, int): + raise TypeError("subtype must be an instance of int") + if subtype >= 256 or subtype < 0: + raise ValueError("subtype must be contained in [0, 256)") + # Support any type that implements the buffer protocol. + self = bytes.__new__(cls, memoryview(data).tobytes()) + self.__subtype = subtype + return self + + @classmethod + def from_uuid(cls, uuid, uuid_representation=UuidRepresentation.STANDARD): + """Create a BSON Binary object from a Python UUID. + + Creates a :class:`~bson.binary.Binary` object from a + :class:`uuid.UUID` instance. Assumes that the native + :class:`uuid.UUID` instance uses the byte-order implied by the + provided ``uuid_representation``. + + Raises :exc:`TypeError` if `uuid` is not an instance of + :class:`~uuid.UUID`. + + :Parameters: + - `uuid`: A :class:`uuid.UUID` instance. + - `uuid_representation`: A member of + :class:`~bson.binary.UuidRepresentation`. Default: + :const:`~bson.binary.UuidRepresentation.STANDARD`. + See :ref:`handling-uuid-data-example` for details. + + .. versionadded:: 3.11 + """ + if not isinstance(uuid, UUID): + raise TypeError("uuid must be an instance of uuid.UUID") + + if uuid_representation not in ALL_UUID_REPRESENTATIONS: + raise ValueError("uuid_representation must be a value " + "from bson.binary.UuidRepresentation") + + if uuid_representation == UuidRepresentation.UNSPECIFIED: + raise ValueError( + "cannot encode native uuid.UUID with " + "UuidRepresentation.UNSPECIFIED. UUIDs can be manually " + "converted to bson.Binary instances using " + "bson.Binary.from_uuid() or a different UuidRepresentation " + "can be configured. See the documentation for " + "UuidRepresentation for more information.") + + subtype = OLD_UUID_SUBTYPE + if uuid_representation == UuidRepresentation.PYTHON_LEGACY: + payload = uuid.bytes + elif uuid_representation == UuidRepresentation.JAVA_LEGACY: + from_uuid = uuid.bytes + payload = from_uuid[0:8][::-1] + from_uuid[8:16][::-1] + elif uuid_representation == UuidRepresentation.CSHARP_LEGACY: + payload = uuid.bytes_le + else: + # uuid_representation == UuidRepresentation.STANDARD + subtype = UUID_SUBTYPE + payload = uuid.bytes + + return cls(payload, subtype) + + def as_uuid(self, uuid_representation=UuidRepresentation.STANDARD): + """Create a Python UUID from this BSON Binary object. + + Decodes this binary object as a native :class:`uuid.UUID` instance + with the provided ``uuid_representation``. + + Raises :exc:`ValueError` if this :class:`~bson.binary.Binary` instance + does not contain a UUID. + + :Parameters: + - `uuid_representation`: A member of + :class:`~bson.binary.UuidRepresentation`. Default: + :const:`~bson.binary.UuidRepresentation.STANDARD`. + See :ref:`handling-uuid-data-example` for details. + + .. versionadded:: 3.11 + """ + if self.subtype not in ALL_UUID_SUBTYPES: + raise ValueError("cannot decode subtype %s as a uuid" % ( + self.subtype,)) + + if uuid_representation not in ALL_UUID_REPRESENTATIONS: + raise ValueError("uuid_representation must be a value from " + "bson.binary.UuidRepresentation") + + if uuid_representation == UuidRepresentation.UNSPECIFIED: + raise ValueError("uuid_representation cannot be UNSPECIFIED") + elif uuid_representation == UuidRepresentation.PYTHON_LEGACY: + if self.subtype == OLD_UUID_SUBTYPE: + return UUID(bytes=self) + elif uuid_representation == UuidRepresentation.JAVA_LEGACY: + if self.subtype == OLD_UUID_SUBTYPE: + return UUID(bytes=self[0:8][::-1] + self[8:16][::-1]) + elif uuid_representation == UuidRepresentation.CSHARP_LEGACY: + if self.subtype == OLD_UUID_SUBTYPE: + return UUID(bytes_le=self) + else: + # uuid_representation == UuidRepresentation.STANDARD + if self.subtype == UUID_SUBTYPE: + return UUID(bytes=self) + + raise ValueError("cannot decode subtype %s to %s" % ( + self.subtype, UUID_REPRESENTATION_NAMES[uuid_representation])) + + @property + def subtype(self): + """Subtype of this binary data. + """ + return self.__subtype + + def __getnewargs__(self): + # Work around http://bugs.python.org/issue7382 + data = super(Binary, self).__getnewargs__()[0] + if PY3 and not isinstance(data, bytes): + data = data.encode('latin-1') + return data, self.__subtype + + def __eq__(self, other): + if isinstance(other, Binary): + return ((self.__subtype, bytes(self)) == + (other.subtype, bytes(other))) + # We don't return NotImplemented here because if we did then + # Binary("foo") == "foo" would return True, since Binary is a + # subclass of str... + return False + + def __hash__(self): + return super(Binary, self).__hash__() ^ hash(self.__subtype) + + def __ne__(self, other): + return not self == other + + def __repr__(self): + return "Binary(%s, %s)" % (bytes.__repr__(self), self.__subtype) + + +class UUIDLegacy(Binary): + """**DEPRECATED** - UUID wrapper to support working with UUIDs stored as + PYTHON_LEGACY. + + .. note:: This class has been deprecated and will be removed in + PyMongo 4.0. Use :meth:`~bson.binary.Binary.from_uuid` and + :meth:`~bson.binary.Binary.as_uuid` with the appropriate + :class:`~bson.binary.UuidRepresentation` to handle legacy-formatted + UUIDs instead.:: + + from bson import Binary, UUIDLegacy, UuidRepresentation + import uuid + + my_uuid = uuid.uuid4() + legacy_uuid = UUIDLegacy(my_uuid) + binary_uuid = Binary.from_uuid( + my_uuid, UuidRepresentation.PYTHON_LEGACY) + + assert legacy_uuid == binary_uuid + assert legacy_uuid.uuid == binary_uuid.as_uuid( + UuidRepresentation.PYTHON_LEGACY) + + .. doctest:: + + >>> import uuid + >>> from bson.binary import Binary, UUIDLegacy, STANDARD + >>> from bson.codec_options import CodecOptions + >>> my_uuid = uuid.uuid4() + >>> coll = db.get_collection('test', + ... CodecOptions(uuid_representation=STANDARD)) + >>> coll.insert_one({'uuid': Binary(my_uuid.bytes, 3)}).inserted_id + ObjectId('...') + >>> coll.count_documents({'uuid': my_uuid}) + 0 + >>> coll.count_documents({'uuid': UUIDLegacy(my_uuid)}) + 1 + >>> coll.find({'uuid': UUIDLegacy(my_uuid)})[0]['uuid'] + UUID('...') + >>> + >>> # Convert from subtype 3 to subtype 4 + >>> doc = coll.find_one({'uuid': UUIDLegacy(my_uuid)}) + >>> coll.replace_one({"_id": doc["_id"]}, doc).matched_count + 1 + >>> coll.count_documents({'uuid': UUIDLegacy(my_uuid)}) + 0 + >>> coll.count_documents({'uuid': {'$in': [UUIDLegacy(my_uuid), my_uuid]}}) + 1 + >>> coll.find_one({'uuid': my_uuid})['uuid'] + UUID('...') + + Raises :exc:`TypeError` if `obj` is not an instance of :class:`~uuid.UUID`. + + :Parameters: + - `obj`: An instance of :class:`~uuid.UUID`. + + .. versionchanged:: 3.11 + Deprecated. The same functionality can be replicated using the + :meth:`~Binary.from_uuid` and :meth:`~Binary.to_uuid` methods with + :data:`~UuidRepresentation.PYTHON_LEGACY`. + .. versionadded:: 2.1 + """ + + def __new__(cls, obj): + warn( + "The UUIDLegacy class has been deprecated and will be removed " + "in PyMongo 4.0. Use the Binary.from_uuid() and Binary.to_uuid() " + "with the appropriate UuidRepresentation to handle " + "legacy-formatted UUIDs instead.", + DeprecationWarning, stacklevel=2) + if not isinstance(obj, UUID): + raise TypeError("obj must be an instance of uuid.UUID") + self = Binary.__new__(cls, obj.bytes, OLD_UUID_SUBTYPE) + self.__uuid = obj + return self + + def __getnewargs__(self): + # Support copy and deepcopy + return (self.__uuid,) + + @property + def uuid(self): + """UUID instance wrapped by this UUIDLegacy instance. + """ + return self.__uuid + + def __repr__(self): + return "UUIDLegacy('%s')" % self.__uuid diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/code.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/code.py new file mode 100644 index 00000000..3f6e5043 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/code.py @@ -0,0 +1,99 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""Tools for representing JavaScript code in BSON. +""" + +from bson.py3compat import abc, string_type, PY3, text_type + + +class Code(str): + """BSON's JavaScript code type. + + Raises :class:`TypeError` if `code` is not an instance of + :class:`basestring` (:class:`str` in python 3) or `scope` + is not ``None`` or an instance of :class:`dict`. + + Scope variables can be set by passing a dictionary as the `scope` + argument or by using keyword arguments. If a variable is set as a + keyword argument it will override any setting for that variable in + the `scope` dictionary. + + :Parameters: + - `code`: A string containing JavaScript code to be evaluated or another + instance of Code. In the latter case, the scope of `code` becomes this + Code's :attr:`scope`. + - `scope` (optional): dictionary representing the scope in which + `code` should be evaluated - a mapping from identifiers (as + strings) to values. Defaults to ``None``. This is applied after any + scope associated with a given `code` above. + - `**kwargs` (optional): scope variables can also be passed as + keyword arguments. These are applied after `scope` and `code`. + + .. versionchanged:: 3.4 + The default value for :attr:`scope` is ``None`` instead of ``{}``. + + """ + + _type_marker = 13 + + def __new__(cls, code, scope=None, **kwargs): + if not isinstance(code, string_type): + raise TypeError("code must be an " + "instance of %s" % (string_type.__name__)) + + if not PY3 and isinstance(code, text_type): + self = str.__new__(cls, code.encode('utf8')) + else: + self = str.__new__(cls, code) + + try: + self.__scope = code.scope + except AttributeError: + self.__scope = None + + if scope is not None: + if not isinstance(scope, abc.Mapping): + raise TypeError("scope must be an instance of dict") + if self.__scope is not None: + self.__scope.update(scope) + else: + self.__scope = scope + + if kwargs: + if self.__scope is not None: + self.__scope.update(kwargs) + else: + self.__scope = kwargs + + return self + + @property + def scope(self): + """Scope dictionary for this instance or ``None``. + """ + return self.__scope + + def __repr__(self): + return "Code(%s, %r)" % (str.__repr__(self), self.__scope) + + def __eq__(self, other): + if isinstance(other, Code): + return (self.__scope, str(self)) == (other.__scope, str(other)) + return False + + __hash__ = None + + def __ne__(self, other): + return not self == other diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/codec_options.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/codec_options.py new file mode 100644 index 00000000..8b848290 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/codec_options.py @@ -0,0 +1,346 @@ +# Copyright 2014-present MongoDB, Inc. +# +# 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. + +"""Tools for specifying BSON codec options.""" + +import datetime +import warnings + +from abc import abstractmethod +from collections import namedtuple + +from bson.py3compat import ABC, abc, abstractproperty, string_type + +from bson.binary import (UuidRepresentation, + ALL_UUID_REPRESENTATIONS, + UUID_REPRESENTATION_NAMES) + + +_RAW_BSON_DOCUMENT_MARKER = 101 + + +def _raw_document_class(document_class): + """Determine if a document_class is a RawBSONDocument class.""" + marker = getattr(document_class, '_type_marker', None) + return marker == _RAW_BSON_DOCUMENT_MARKER + + +class TypeEncoder(ABC): + """Base class for defining type codec classes which describe how a + custom type can be transformed to one of the types BSON understands. + + Codec classes must implement the ``python_type`` attribute, and the + ``transform_python`` method to support encoding. + + See :ref:`custom-type-type-codec` documentation for an example. + """ + @abstractproperty + def python_type(self): + """The Python type to be converted into something serializable.""" + pass + + @abstractmethod + def transform_python(self, value): + """Convert the given Python object into something serializable.""" + pass + + +class TypeDecoder(ABC): + """Base class for defining type codec classes which describe how a + BSON type can be transformed to a custom type. + + Codec classes must implement the ``bson_type`` attribute, and the + ``transform_bson`` method to support decoding. + + See :ref:`custom-type-type-codec` documentation for an example. + """ + @abstractproperty + def bson_type(self): + """The BSON type to be converted into our own type.""" + pass + + @abstractmethod + def transform_bson(self, value): + """Convert the given BSON value into our own type.""" + pass + + +class TypeCodec(TypeEncoder, TypeDecoder): + """Base class for defining type codec classes which describe how a + custom type can be transformed to/from one of the types :mod:`bson` + can already encode/decode. + + Codec classes must implement the ``python_type`` attribute, and the + ``transform_python`` method to support encoding, as well as the + ``bson_type`` attribute, and the ``transform_bson`` method to support + decoding. + + See :ref:`custom-type-type-codec` documentation for an example. + """ + pass + + +class TypeRegistry(object): + """Encapsulates type codecs used in encoding and / or decoding BSON, as + well as the fallback encoder. Type registries cannot be modified after + instantiation. + + ``TypeRegistry`` can be initialized with an iterable of type codecs, and + a callable for the fallback encoder:: + + >>> from bson.codec_options import TypeRegistry + >>> type_registry = TypeRegistry([Codec1, Codec2, Codec3, ...], + ... fallback_encoder) + + See :ref:`custom-type-type-registry` documentation for an example. + + :Parameters: + - `type_codecs` (optional): iterable of type codec instances. If + ``type_codecs`` contains multiple codecs that transform a single + python or BSON type, the transformation specified by the type codec + occurring last prevails. A TypeError will be raised if one or more + type codecs modify the encoding behavior of a built-in :mod:`bson` + type. + - `fallback_encoder` (optional): callable that accepts a single, + unencodable python value and transforms it into a type that + :mod:`bson` can encode. See :ref:`fallback-encoder-callable` + documentation for an example. + """ + def __init__(self, type_codecs=None, fallback_encoder=None): + self.__type_codecs = list(type_codecs or []) + self._fallback_encoder = fallback_encoder + self._encoder_map = {} + self._decoder_map = {} + + if self._fallback_encoder is not None: + if not callable(fallback_encoder): + raise TypeError("fallback_encoder %r is not a callable" % ( + fallback_encoder)) + + for codec in self.__type_codecs: + is_valid_codec = False + if isinstance(codec, TypeEncoder): + self._validate_type_encoder(codec) + is_valid_codec = True + self._encoder_map[codec.python_type] = codec.transform_python + if isinstance(codec, TypeDecoder): + is_valid_codec = True + self._decoder_map[codec.bson_type] = codec.transform_bson + if not is_valid_codec: + raise TypeError( + "Expected an instance of %s, %s, or %s, got %r instead" % ( + TypeEncoder.__name__, TypeDecoder.__name__, + TypeCodec.__name__, codec)) + + def _validate_type_encoder(self, codec): + from bson import _BUILT_IN_TYPES + for pytype in _BUILT_IN_TYPES: + if issubclass(codec.python_type, pytype): + err_msg = ("TypeEncoders cannot change how built-in types are " + "encoded (encoder %s transforms type %s)" % + (codec, pytype)) + raise TypeError(err_msg) + + def __repr__(self): + return ('%s(type_codecs=%r, fallback_encoder=%r)' % ( + self.__class__.__name__, self.__type_codecs, + self._fallback_encoder)) + + def __eq__(self, other): + if not isinstance(other, type(self)): + return NotImplemented + return ((self._decoder_map == other._decoder_map) and + (self._encoder_map == other._encoder_map) and + (self._fallback_encoder == other._fallback_encoder)) + + +_options_base = namedtuple( + 'CodecOptions', + ('document_class', 'tz_aware', 'uuid_representation', + 'unicode_decode_error_handler', 'tzinfo', 'type_registry')) + + +class CodecOptions(_options_base): + """Encapsulates options used encoding and / or decoding BSON. + + The `document_class` option is used to define a custom type for use + decoding BSON documents. Access to the underlying raw BSON bytes for + a document is available using the :class:`~bson.raw_bson.RawBSONDocument` + type:: + + >>> from bson.raw_bson import RawBSONDocument + >>> from bson.codec_options import CodecOptions + >>> codec_options = CodecOptions(document_class=RawBSONDocument) + >>> coll = db.get_collection('test', codec_options=codec_options) + >>> doc = coll.find_one() + >>> doc.raw + '\\x16\\x00\\x00\\x00\\x07_id\\x00[0\\x165\\x91\\x10\\xea\\x14\\xe8\\xc5\\x8b\\x93\\x00' + + The document class can be any type that inherits from + :class:`~collections.MutableMapping`:: + + >>> class AttributeDict(dict): + ... # A dict that supports attribute access. + ... def __getattr__(self, key): + ... return self[key] + ... def __setattr__(self, key, value): + ... self[key] = value + ... + >>> codec_options = CodecOptions(document_class=AttributeDict) + >>> coll = db.get_collection('test', codec_options=codec_options) + >>> doc = coll.find_one() + >>> doc._id + ObjectId('5b3016359110ea14e8c58b93') + + See :doc:`/examples/datetimes` for examples using the `tz_aware` and + `tzinfo` options. + + See :class:`~bson.binary.UUIDLegacy` for examples using the + `uuid_representation` option. + + :Parameters: + - `document_class`: BSON documents returned in queries will be decoded + to an instance of this class. Must be a subclass of + :class:`~collections.MutableMapping`. Defaults to :class:`dict`. + - `tz_aware`: If ``True``, BSON datetimes will be decoded to timezone + aware instances of :class:`~datetime.datetime`. Otherwise they will be + naive. Defaults to ``False``. + - `uuid_representation`: The BSON representation to use when encoding + and decoding instances of :class:`~uuid.UUID`. Defaults to + :data:`~bson.binary.UuidRepresentation.PYTHON_LEGACY`. New + applications should consider setting this to + :data:`~bson.binary.UuidRepresentation.STANDARD` for cross language + compatibility. See :ref:`handling-uuid-data-example` for details. + - `unicode_decode_error_handler`: The error handler to apply when + a Unicode-related error occurs during BSON decoding that would + otherwise raise :exc:`UnicodeDecodeError`. Valid options include + 'strict', 'replace', and 'ignore'. Defaults to 'strict'. + - `tzinfo`: A :class:`~datetime.tzinfo` subclass that specifies the + timezone to/from which :class:`~datetime.datetime` objects should be + encoded/decoded. + - `type_registry`: Instance of :class:`TypeRegistry` used to customize + encoding and decoding behavior. + + .. versionadded:: 3.8 + `type_registry` attribute. + + .. warning:: Care must be taken when changing + `unicode_decode_error_handler` from its default value ('strict'). + The 'replace' and 'ignore' modes should not be used when documents + retrieved from the server will be modified in the client application + and stored back to the server. + """ + + def __new__(cls, document_class=dict, + tz_aware=False, + uuid_representation=None, + unicode_decode_error_handler="strict", + tzinfo=None, type_registry=None): + if not (issubclass(document_class, abc.MutableMapping) or + _raw_document_class(document_class)): + raise TypeError("document_class must be dict, bson.son.SON, " + "bson.raw_bson.RawBSONDocument, or a " + "sublass of collections.MutableMapping") + if not isinstance(tz_aware, bool): + raise TypeError("tz_aware must be True or False") + if uuid_representation is None: + uuid_representation = UuidRepresentation.PYTHON_LEGACY + elif uuid_representation not in ALL_UUID_REPRESENTATIONS: + raise ValueError("uuid_representation must be a value " + "from bson.binary.UuidRepresentation") + if not isinstance(unicode_decode_error_handler, (string_type, None)): + raise ValueError("unicode_decode_error_handler must be a string " + "or None") + if tzinfo is not None: + if not isinstance(tzinfo, datetime.tzinfo): + raise TypeError( + "tzinfo must be an instance of datetime.tzinfo") + if not tz_aware: + raise ValueError( + "cannot specify tzinfo without also setting tz_aware=True") + + type_registry = type_registry or TypeRegistry() + + if not isinstance(type_registry, TypeRegistry): + raise TypeError("type_registry must be an instance of TypeRegistry") + + return tuple.__new__( + cls, (document_class, tz_aware, uuid_representation, + unicode_decode_error_handler, tzinfo, type_registry)) + + def _arguments_repr(self): + """Representation of the arguments used to create this object.""" + document_class_repr = ( + 'dict' if self.document_class is dict + else repr(self.document_class)) + + uuid_rep_repr = UUID_REPRESENTATION_NAMES.get(self.uuid_representation, + self.uuid_representation) + + return ('document_class=%s, tz_aware=%r, uuid_representation=%s, ' + 'unicode_decode_error_handler=%r, tzinfo=%r, ' + 'type_registry=%r' % + (document_class_repr, self.tz_aware, uuid_rep_repr, + self.unicode_decode_error_handler, self.tzinfo, + self.type_registry)) + + def _options_dict(self): + """Dictionary of the arguments used to create this object.""" + # TODO: PYTHON-2442 use _asdict() instead + return { + 'document_class': self.document_class, + 'tz_aware': self.tz_aware, + 'uuid_representation': self.uuid_representation, + 'unicode_decode_error_handler': self.unicode_decode_error_handler, + 'tzinfo': self.tzinfo, + 'type_registry': self.type_registry} + + def __repr__(self): + return '%s(%s)' % (self.__class__.__name__, self._arguments_repr()) + + def with_options(self, **kwargs): + """Make a copy of this CodecOptions, overriding some options:: + + >>> from bson.codec_options import DEFAULT_CODEC_OPTIONS + >>> DEFAULT_CODEC_OPTIONS.tz_aware + False + >>> options = DEFAULT_CODEC_OPTIONS.with_options(tz_aware=True) + >>> options.tz_aware + True + + .. versionadded:: 3.5 + """ + opts = self._options_dict() + opts.update(kwargs) + return CodecOptions(**opts) + + +DEFAULT_CODEC_OPTIONS = CodecOptions( + uuid_representation=UuidRepresentation.PYTHON_LEGACY) + + +def _parse_codec_options(options): + """Parse BSON codec options.""" + return CodecOptions( + document_class=options.get( + 'document_class', DEFAULT_CODEC_OPTIONS.document_class), + tz_aware=options.get( + 'tz_aware', DEFAULT_CODEC_OPTIONS.tz_aware), + uuid_representation=options.get('uuidrepresentation'), + unicode_decode_error_handler=options.get( + 'unicode_decode_error_handler', + DEFAULT_CODEC_OPTIONS.unicode_decode_error_handler), + tzinfo=options.get('tzinfo', DEFAULT_CODEC_OPTIONS.tzinfo), + type_registry=options.get( + 'type_registry', DEFAULT_CODEC_OPTIONS.type_registry)) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/dbref.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/dbref.py new file mode 100644 index 00000000..3c9ae5f4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/dbref.py @@ -0,0 +1,135 @@ +# Copyright 2009-2015 MongoDB, Inc. +# +# 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. + +"""Tools for manipulating DBRefs (references to MongoDB documents).""" + +from copy import deepcopy + +from bson.py3compat import iteritems, string_type +from bson.son import SON + + +class DBRef(object): + """A reference to a document stored in MongoDB. + """ + + # DBRef isn't actually a BSON "type" so this number was arbitrarily chosen. + _type_marker = 100 + + def __init__(self, collection, id, database=None, _extra={}, **kwargs): + """Initialize a new :class:`DBRef`. + + Raises :class:`TypeError` if `collection` or `database` is not + an instance of :class:`basestring` (:class:`str` in python 3). + `database` is optional and allows references to documents to work + across databases. Any additional keyword arguments will create + additional fields in the resultant embedded document. + + :Parameters: + - `collection`: name of the collection the document is stored in + - `id`: the value of the document's ``"_id"`` field + - `database` (optional): name of the database to reference + - `**kwargs` (optional): additional keyword arguments will + create additional, custom fields + + .. seealso:: The MongoDB documentation on `dbrefs `_. + """ + if not isinstance(collection, string_type): + raise TypeError("collection must be an " + "instance of %s" % string_type.__name__) + if database is not None and not isinstance(database, string_type): + raise TypeError("database must be an " + "instance of %s" % string_type.__name__) + + self.__collection = collection + self.__id = id + self.__database = database + kwargs.update(_extra) + self.__kwargs = kwargs + + @property + def collection(self): + """Get the name of this DBRef's collection as unicode. + """ + return self.__collection + + @property + def id(self): + """Get this DBRef's _id. + """ + return self.__id + + @property + def database(self): + """Get the name of this DBRef's database. + + Returns None if this DBRef doesn't specify a database. + """ + return self.__database + + def __getattr__(self, key): + try: + return self.__kwargs[key] + except KeyError: + raise AttributeError(key) + + # Have to provide __setstate__ to avoid + # infinite recursion since we override + # __getattr__. + def __setstate__(self, state): + self.__dict__.update(state) + + def as_doc(self): + """Get the SON document representation of this DBRef. + + Generally not needed by application developers + """ + doc = SON([("$ref", self.collection), + ("$id", self.id)]) + if self.database is not None: + doc["$db"] = self.database + doc.update(self.__kwargs) + return doc + + def __repr__(self): + extra = "".join([", %s=%r" % (k, v) + for k, v in iteritems(self.__kwargs)]) + if self.database is None: + return "DBRef(%r, %r%s)" % (self.collection, self.id, extra) + return "DBRef(%r, %r, %r%s)" % (self.collection, self.id, + self.database, extra) + + def __eq__(self, other): + if isinstance(other, DBRef): + us = (self.__database, self.__collection, + self.__id, self.__kwargs) + them = (other.__database, other.__collection, + other.__id, other.__kwargs) + return us == them + return NotImplemented + + def __ne__(self, other): + return not self == other + + def __hash__(self): + """Get a hash value for this :class:`DBRef`.""" + return hash((self.__collection, self.__id, self.__database, + tuple(sorted(self.__kwargs.items())))) + + def __deepcopy__(self, memo): + """Support function for `copy.deepcopy()`.""" + return DBRef(deepcopy(self.__collection, memo), + deepcopy(self.__id, memo), + deepcopy(self.__database, memo), + deepcopy(self.__kwargs, memo)) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/decimal128.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/decimal128.py new file mode 100644 index 00000000..0c0fc10c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/decimal128.py @@ -0,0 +1,335 @@ +# Copyright 2016-present MongoDB, Inc. +# +# 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. + +"""Tools for working with the BSON decimal128 type. + +.. versionadded:: 3.4 + +.. note:: The Decimal128 BSON type requires MongoDB 3.4+. +""" + +import decimal +import struct +import sys + +from bson.py3compat import (PY3 as _PY3, + string_type as _string_type) + + +if _PY3: + _from_bytes = int.from_bytes # pylint: disable=no-member, invalid-name +else: + import binascii + def _from_bytes(value, dummy, _int=int, _hexlify=binascii.hexlify): + "An implementation of int.from_bytes for python 2.x." + return _int(_hexlify(value), 16) + + +_PACK_64 = struct.Struct("= 3.3, cdecimal + decimal.Context(clamp=1) # pylint: disable=unexpected-keyword-arg + _CTX_OPTIONS['clamp'] = 1 +except TypeError: + # Python < 3.3 + _CTX_OPTIONS['_clamp'] = 1 + +_DEC128_CTX = decimal.Context(**_CTX_OPTIONS.copy()) + + +def create_decimal128_context(): + """Returns an instance of :class:`decimal.Context` appropriate + for working with IEEE-754 128-bit decimal floating point values. + """ + opts = _CTX_OPTIONS.copy() + opts['traps'] = [] + return decimal.Context(**opts) + + +def _decimal_to_128(value): + """Converts a decimal.Decimal to BID (high bits, low bits). + + :Parameters: + - `value`: An instance of decimal.Decimal + """ + with decimal.localcontext(_DEC128_CTX) as ctx: + value = ctx.create_decimal(value) + + if value.is_infinite(): + return _NINF if value.is_signed() else _PINF + + sign, digits, exponent = value.as_tuple() + + if value.is_nan(): + if digits: + raise ValueError("NaN with debug payload is not supported") + if value.is_snan(): + return _NSNAN if value.is_signed() else _PSNAN + return _NNAN if value.is_signed() else _PNAN + + significand = int("".join([str(digit) for digit in digits])) + bit_length = significand.bit_length() + + high = 0 + low = 0 + for i in range(min(64, bit_length)): + if significand & (1 << i): + low |= 1 << i + + for i in range(64, bit_length): + if significand & (1 << i): + high |= 1 << (i - 64) + + biased_exponent = exponent + _EXPONENT_BIAS + + if high >> 49 == 1: + high = high & 0x7fffffffffff + high |= _EXPONENT_MASK + high |= (biased_exponent & 0x3fff) << 47 + else: + high |= biased_exponent << 49 + + if sign: + high |= _SIGN + + return high, low + + +class Decimal128(object): + """BSON Decimal128 type:: + + >>> Decimal128(Decimal("0.0005")) + Decimal128('0.0005') + >>> Decimal128("0.0005") + Decimal128('0.0005') + >>> Decimal128((3474527112516337664, 5)) + Decimal128('0.0005') + + :Parameters: + - `value`: An instance of :class:`decimal.Decimal`, string, or tuple of + (high bits, low bits) from Binary Integer Decimal (BID) format. + + .. note:: :class:`~Decimal128` uses an instance of :class:`decimal.Context` + configured for IEEE-754 Decimal128 when validating parameters. + Signals like :class:`decimal.InvalidOperation`, :class:`decimal.Inexact`, + and :class:`decimal.Overflow` are trapped and raised as exceptions:: + + >>> Decimal128(".13.1") + Traceback (most recent call last): + File "", line 1, in + ... + decimal.InvalidOperation: [] + >>> + >>> Decimal128("1E-6177") + Traceback (most recent call last): + File "", line 1, in + ... + decimal.Inexact: [] + >>> + >>> Decimal128("1E6145") + Traceback (most recent call last): + File "", line 1, in + ... + decimal.Overflow: [, ] + + To ensure the result of a calculation can always be stored as BSON + Decimal128 use the context returned by + :func:`create_decimal128_context`:: + + >>> import decimal + >>> decimal128_ctx = create_decimal128_context() + >>> with decimal.localcontext(decimal128_ctx) as ctx: + ... Decimal128(ctx.create_decimal(".13.3")) + ... + Decimal128('NaN') + >>> + >>> with decimal.localcontext(decimal128_ctx) as ctx: + ... Decimal128(ctx.create_decimal("1E-6177")) + ... + Decimal128('0E-6176') + >>> + >>> with decimal.localcontext(DECIMAL128_CTX) as ctx: + ... Decimal128(ctx.create_decimal("1E6145")) + ... + Decimal128('Infinity') + + To match the behavior of MongoDB's Decimal128 implementation + str(Decimal(value)) may not match str(Decimal128(value)) for NaN values:: + + >>> Decimal128(Decimal('NaN')) + Decimal128('NaN') + >>> Decimal128(Decimal('-NaN')) + Decimal128('NaN') + >>> Decimal128(Decimal('sNaN')) + Decimal128('NaN') + >>> Decimal128(Decimal('-sNaN')) + Decimal128('NaN') + + However, :meth:`~Decimal128.to_decimal` will return the exact value:: + + >>> Decimal128(Decimal('NaN')).to_decimal() + Decimal('NaN') + >>> Decimal128(Decimal('-NaN')).to_decimal() + Decimal('-NaN') + >>> Decimal128(Decimal('sNaN')).to_decimal() + Decimal('sNaN') + >>> Decimal128(Decimal('-sNaN')).to_decimal() + Decimal('-sNaN') + + Two instances of :class:`Decimal128` compare equal if their Binary + Integer Decimal encodings are equal:: + + >>> Decimal128('NaN') == Decimal128('NaN') + True + >>> Decimal128('NaN').bid == Decimal128('NaN').bid + True + + This differs from :class:`decimal.Decimal` comparisons for NaN:: + + >>> Decimal('NaN') == Decimal('NaN') + False + """ + __slots__ = ('__high', '__low') + + _type_marker = 19 + + def __init__(self, value): + if isinstance(value, (_string_type, decimal.Decimal)): + self.__high, self.__low = _decimal_to_128(value) + elif isinstance(value, (list, tuple)): + if len(value) != 2: + raise ValueError('Invalid size for creation of Decimal128 ' + 'from list or tuple. Must have exactly 2 ' + 'elements.') + self.__high, self.__low = value + else: + raise TypeError("Cannot convert %r to Decimal128" % (value,)) + + def to_decimal(self): + """Returns an instance of :class:`decimal.Decimal` for this + :class:`Decimal128`. + """ + high = self.__high + low = self.__low + sign = 1 if (high & _SIGN) else 0 + + if (high & _SNAN) == _SNAN: + return decimal.Decimal((sign, (), 'N')) + elif (high & _NAN) == _NAN: + return decimal.Decimal((sign, (), 'n')) + elif (high & _INF) == _INF: + return decimal.Decimal((sign, (), 'F')) + + if (high & _EXPONENT_MASK) == _EXPONENT_MASK: + exponent = ((high & 0x1fffe00000000000) >> 47) - _EXPONENT_BIAS + return decimal.Decimal((sign, (0,), exponent)) + else: + exponent = ((high & 0x7fff800000000000) >> 49) - _EXPONENT_BIAS + + arr = bytearray(15) + mask = 0x00000000000000ff + for i in range(14, 6, -1): + arr[i] = (low & mask) >> ((14 - i) << 3) + mask = mask << 8 + + mask = 0x00000000000000ff + for i in range(6, 0, -1): + arr[i] = (high & mask) >> ((6 - i) << 3) + mask = mask << 8 + + mask = 0x0001000000000000 + arr[0] = (high & mask) >> 48 + + # cdecimal only accepts a tuple for digits. + digits = tuple( + int(digit) for digit in str(_from_bytes(arr, 'big'))) + + with decimal.localcontext(_DEC128_CTX) as ctx: + return ctx.create_decimal((sign, digits, exponent)) + + @classmethod + def from_bid(cls, value): + """Create an instance of :class:`Decimal128` from Binary Integer + Decimal string. + + :Parameters: + - `value`: 16 byte string (128-bit IEEE 754-2008 decimal floating + point in Binary Integer Decimal (BID) format). + """ + if not isinstance(value, bytes): + raise TypeError("value must be an instance of bytes") + if len(value) != 16: + raise ValueError("value must be exactly 16 bytes") + return cls((_UNPACK_64(value[8:])[0], _UNPACK_64(value[:8])[0])) + + @property + def bid(self): + """The Binary Integer Decimal (BID) encoding of this instance.""" + return _PACK_64(self.__low) + _PACK_64(self.__high) + + def __str__(self): + dec = self.to_decimal() + if dec.is_nan(): + # Required by the drivers spec to match MongoDB behavior. + return "NaN" + return str(dec) + + def __repr__(self): + return "Decimal128('%s')" % (str(self),) + + def __setstate__(self, value): + self.__high, self.__low = value + + def __getstate__(self): + return self.__high, self.__low + + def __eq__(self, other): + if isinstance(other, Decimal128): + return self.bid == other.bid + return NotImplemented + + def __ne__(self, other): + return not self == other diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/errors.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/errors.py new file mode 100644 index 00000000..9bdb7413 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/errors.py @@ -0,0 +1,40 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""Exceptions raised by the BSON package.""" + + +class BSONError(Exception): + """Base class for all BSON exceptions. + """ + + +class InvalidBSON(BSONError): + """Raised when trying to create a BSON object from invalid data. + """ + + +class InvalidStringData(BSONError): + """Raised when trying to encode a string containing non-UTF8 data. + """ + + +class InvalidDocument(BSONError): + """Raised when trying to create a BSON object from an invalid document. + """ + + +class InvalidId(BSONError): + """Raised when trying to create an ObjectId from invalid data. + """ diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/int64.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/int64.py new file mode 100644 index 00000000..77e98123 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/int64.py @@ -0,0 +1,34 @@ +# Copyright 2014-2015 MongoDB, Inc. +# +# 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. + +"""A BSON wrapper for long (int in python3)""" + +from bson.py3compat import PY3 + +if PY3: + long = int + + +class Int64(long): + """Representation of the BSON int64 type. + + This is necessary because every integral number is an :class:`int` in + Python 3. Small integral numbers are encoded to BSON int32 by default, + but Int64 numbers will always be encoded to BSON int64. + + :Parameters: + - `value`: the numeric value to represent + """ + + _type_marker = 18 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/json_util.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/json_util.py new file mode 100644 index 00000000..38c39a12 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/json_util.py @@ -0,0 +1,863 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""Tools for using Python's :mod:`json` module with BSON documents. + +This module provides two helper methods `dumps` and `loads` that wrap the +native :mod:`json` methods and provide explicit BSON conversion to and from +JSON. :class:`~bson.json_util.JSONOptions` provides a way to control how JSON +is emitted and parsed, with the default being the legacy PyMongo format. +:mod:`~bson.json_util` can also generate Canonical or Relaxed `Extended JSON`_ +when :const:`CANONICAL_JSON_OPTIONS` or :const:`RELAXED_JSON_OPTIONS` is +provided, respectively. + +.. _Extended JSON: https://github.com/mongodb/specifications/blob/master/source/extended-json.rst + +Example usage (deserialization): + +.. doctest:: + + >>> from bson.json_util import loads + >>> loads('[{"foo": [1, 2]}, {"bar": {"hello": "world"}}, {"code": {"$scope": {}, "$code": "function x() { return 1; }"}}, {"bin": {"$type": "80", "$binary": "AQIDBA=="}}]') + [{u'foo': [1, 2]}, {u'bar': {u'hello': u'world'}}, {u'code': Code('function x() { return 1; }', {})}, {u'bin': Binary('...', 128)}] + +Example usage (serialization): + +.. doctest:: + + >>> from bson import Binary, Code + >>> from bson.json_util import dumps + >>> dumps([{'foo': [1, 2]}, + ... {'bar': {'hello': 'world'}}, + ... {'code': Code("function x() { return 1; }", {})}, + ... {'bin': Binary(b"\x01\x02\x03\x04")}]) + '[{"foo": [1, 2]}, {"bar": {"hello": "world"}}, {"code": {"$code": "function x() { return 1; }", "$scope": {}}}, {"bin": {"$binary": "AQIDBA==", "$type": "00"}}]' + +Example usage (with :const:`CANONICAL_JSON_OPTIONS`): + +.. doctest:: + + >>> from bson import Binary, Code + >>> from bson.json_util import dumps, CANONICAL_JSON_OPTIONS + >>> dumps([{'foo': [1, 2]}, + ... {'bar': {'hello': 'world'}}, + ... {'code': Code("function x() { return 1; }")}, + ... {'bin': Binary(b"\x01\x02\x03\x04")}], + ... json_options=CANONICAL_JSON_OPTIONS) + '[{"foo": [{"$numberInt": "1"}, {"$numberInt": "2"}]}, {"bar": {"hello": "world"}}, {"code": {"$code": "function x() { return 1; }"}}, {"bin": {"$binary": {"base64": "AQIDBA==", "subType": "00"}}}]' + +Example usage (with :const:`RELAXED_JSON_OPTIONS`): + +.. doctest:: + + >>> from bson import Binary, Code + >>> from bson.json_util import dumps, RELAXED_JSON_OPTIONS + >>> dumps([{'foo': [1, 2]}, + ... {'bar': {'hello': 'world'}}, + ... {'code': Code("function x() { return 1; }")}, + ... {'bin': Binary(b"\x01\x02\x03\x04")}], + ... json_options=RELAXED_JSON_OPTIONS) + '[{"foo": [1, 2]}, {"bar": {"hello": "world"}}, {"code": {"$code": "function x() { return 1; }"}}, {"bin": {"$binary": {"base64": "AQIDBA==", "subType": "00"}}}]' + +Alternatively, you can manually pass the `default` to :func:`json.dumps`. +It won't handle :class:`~bson.binary.Binary` and :class:`~bson.code.Code` +instances (as they are extended strings you can't provide custom defaults), +but it will be faster as there is less recursion. + +.. note:: + If your application does not need the flexibility offered by + :class:`JSONOptions` and spends a large amount of time in the `json_util` + module, look to + `python-bsonjs `_ for a nice + performance improvement. `python-bsonjs` is a fast BSON to MongoDB + Extended JSON converter for Python built on top of + `libbson `_. `python-bsonjs` works best + with PyMongo when using :class:`~bson.raw_bson.RawBSONDocument`. + +.. versionchanged:: 2.8 + The output format for :class:`~bson.timestamp.Timestamp` has changed from + '{"t": , "i": }' to '{"$timestamp": {"t": , "i": }}'. + This new format will be decoded to an instance of + :class:`~bson.timestamp.Timestamp`. The old format will continue to be + decoded to a python dict as before. Encoding to the old format is no longer + supported as it was never correct and loses type information. + Added support for $numberLong and $undefined - new in MongoDB 2.6 - and + parsing $date in ISO-8601 format. + +.. versionchanged:: 2.7 + Preserves order when rendering SON, Timestamp, Code, Binary, and DBRef + instances. + +.. versionchanged:: 2.3 + Added dumps and loads helpers to automatically handle conversion to and + from json and supports :class:`~bson.binary.Binary` and + :class:`~bson.code.Code` +""" + +import base64 +import datetime +import json +import math +import re +import uuid + +from pymongo.errors import ConfigurationError + +import bson +from bson import EPOCH_AWARE, RE_TYPE, SON +from bson.binary import (Binary, UuidRepresentation, ALL_UUID_SUBTYPES, + UUID_SUBTYPE) +from bson.code import Code +from bson.codec_options import CodecOptions +from bson.dbref import DBRef +from bson.decimal128 import Decimal128 +from bson.int64 import Int64 +from bson.max_key import MaxKey +from bson.min_key import MinKey +from bson.objectid import ObjectId +from bson.py3compat import (PY3, iteritems, integer_types, string_type, + text_type) +from bson.regex import Regex +from bson.timestamp import Timestamp +from bson.tz_util import utc + + +_RE_OPT_TABLE = { + "i": re.I, + "l": re.L, + "m": re.M, + "s": re.S, + "u": re.U, + "x": re.X, +} + +# Dollar-prefixed keys which may appear in DBRefs. +_DBREF_KEYS = frozenset(['$id', '$ref', '$db']) + + +class DatetimeRepresentation: + LEGACY = 0 + """Legacy MongoDB Extended JSON datetime representation. + + :class:`datetime.datetime` instances will be encoded to JSON in the + format `{"$date": }`, where `dateAsMilliseconds` is + a 64-bit signed integer giving the number of milliseconds since the Unix + epoch UTC. This was the default encoding before PyMongo version 3.4. + + .. versionadded:: 3.4 + """ + + NUMBERLONG = 1 + """NumberLong datetime representation. + + :class:`datetime.datetime` instances will be encoded to JSON in the + format `{"$date": {"$numberLong": ""}}`, + where `dateAsMilliseconds` is the string representation of a 64-bit signed + integer giving the number of milliseconds since the Unix epoch UTC. + + .. versionadded:: 3.4 + """ + + ISO8601 = 2 + """ISO-8601 datetime representation. + + :class:`datetime.datetime` instances greater than or equal to the Unix + epoch UTC will be encoded to JSON in the format `{"$date": ""}`. + :class:`datetime.datetime` instances before the Unix epoch UTC will be + encoded as if the datetime representation is + :const:`~DatetimeRepresentation.NUMBERLONG`. + + .. versionadded:: 3.4 + """ + + +class JSONMode: + LEGACY = 0 + """Legacy Extended JSON representation. + + In this mode, :func:`~bson.json_util.dumps` produces PyMongo's legacy + non-standard JSON output. Consider using + :const:`~bson.json_util.JSONMode.RELAXED` or + :const:`~bson.json_util.JSONMode.CANONICAL` instead. + + .. versionadded:: 3.5 + """ + + RELAXED = 1 + """Relaxed Extended JSON representation. + + In this mode, :func:`~bson.json_util.dumps` produces Relaxed Extended JSON, + a mostly JSON-like format. Consider using this for things like a web API, + where one is sending a document (or a projection of a document) that only + uses ordinary JSON type primitives. In particular, the ``int``, + :class:`~bson.int64.Int64`, and ``float`` numeric types are represented in + the native JSON number format. This output is also the most human readable + and is useful for debugging and documentation. + + .. seealso:: The specification for Relaxed `Extended JSON`_. + + .. versionadded:: 3.5 + """ + + CANONICAL = 2 + """Canonical Extended JSON representation. + + In this mode, :func:`~bson.json_util.dumps` produces Canonical Extended + JSON, a type preserving format. Consider using this for things like + testing, where one has to precisely specify expected types in JSON. In + particular, the ``int``, :class:`~bson.int64.Int64`, and ``float`` numeric + types are encoded with type wrappers. + + .. seealso:: The specification for Canonical `Extended JSON`_. + + .. versionadded:: 3.5 + """ + + +class JSONOptions(CodecOptions): + """Encapsulates JSON options for :func:`dumps` and :func:`loads`. + + :Parameters: + - `strict_number_long`: If ``True``, :class:`~bson.int64.Int64` objects + are encoded to MongoDB Extended JSON's *Strict mode* type + `NumberLong`, ie ``'{"$numberLong": "" }'``. Otherwise they + will be encoded as an `int`. Defaults to ``False``. + - `datetime_representation`: The representation to use when encoding + instances of :class:`datetime.datetime`. Defaults to + :const:`~DatetimeRepresentation.LEGACY`. + - `strict_uuid`: If ``True``, :class:`uuid.UUID` object are encoded to + MongoDB Extended JSON's *Strict mode* type `Binary`. Otherwise it + will be encoded as ``'{"$uuid": "" }'``. Defaults to ``False``. + - `json_mode`: The :class:`JSONMode` to use when encoding BSON types to + Extended JSON. Defaults to :const:`~JSONMode.LEGACY`. + - `document_class`: BSON documents returned by :func:`loads` will be + decoded to an instance of this class. Must be a subclass of + :class:`collections.MutableMapping`. Defaults to :class:`dict`. + - `uuid_representation`: The :class:`~bson.binary.UuidRepresentation` + to use when encoding and decoding instances of :class:`uuid.UUID`. + Defaults to :const:`~bson.binary.UuidRepresentation.PYTHON_LEGACY`. + - `tz_aware`: If ``True``, MongoDB Extended JSON's *Strict mode* type + `Date` will be decoded to timezone aware instances of + :class:`datetime.datetime`. Otherwise they will be naive. Defaults + to ``True``. + - `tzinfo`: A :class:`datetime.tzinfo` subclass that specifies the + timezone from which :class:`~datetime.datetime` objects should be + decoded. Defaults to :const:`~bson.tz_util.utc`. + - `args`: arguments to :class:`~bson.codec_options.CodecOptions` + - `kwargs`: arguments to :class:`~bson.codec_options.CodecOptions` + + .. seealso:: The specification for Relaxed and Canonical `Extended JSON`_. + + .. versionadded:: 3.4 + + .. versionchanged:: 3.5 + Accepts the optional parameter `json_mode`. + + """ + + def __new__(cls, strict_number_long=False, + datetime_representation=DatetimeRepresentation.LEGACY, + strict_uuid=False, json_mode=JSONMode.LEGACY, + *args, **kwargs): + kwargs["tz_aware"] = kwargs.get("tz_aware", True) + if kwargs["tz_aware"]: + kwargs["tzinfo"] = kwargs.get("tzinfo", utc) + if datetime_representation not in (DatetimeRepresentation.LEGACY, + DatetimeRepresentation.NUMBERLONG, + DatetimeRepresentation.ISO8601): + raise ConfigurationError( + "JSONOptions.datetime_representation must be one of LEGACY, " + "NUMBERLONG, or ISO8601 from DatetimeRepresentation.") + self = super(JSONOptions, cls).__new__(cls, *args, **kwargs) + if json_mode not in (JSONMode.LEGACY, + JSONMode.RELAXED, + JSONMode.CANONICAL): + raise ConfigurationError( + "JSONOptions.json_mode must be one of LEGACY, RELAXED, " + "or CANONICAL from JSONMode.") + self.json_mode = json_mode + if self.json_mode == JSONMode.RELAXED: + self.strict_number_long = False + self.datetime_representation = DatetimeRepresentation.ISO8601 + self.strict_uuid = True + elif self.json_mode == JSONMode.CANONICAL: + self.strict_number_long = True + self.datetime_representation = DatetimeRepresentation.NUMBERLONG + self.strict_uuid = True + else: + self.strict_number_long = strict_number_long + self.datetime_representation = datetime_representation + self.strict_uuid = strict_uuid + return self + + def _arguments_repr(self): + return ('strict_number_long=%r, ' + 'datetime_representation=%r, ' + 'strict_uuid=%r, json_mode=%r, %s' % ( + self.strict_number_long, + self.datetime_representation, + self.strict_uuid, + self.json_mode, + super(JSONOptions, self)._arguments_repr())) + + def _options_dict(self): + # TODO: PYTHON-2442 use _asdict() instead + options_dict = super(JSONOptions, self)._options_dict() + options_dict.update({ + 'strict_number_long': self.strict_number_long, + 'datetime_representation': self.datetime_representation, + 'strict_uuid': self.strict_uuid, + 'json_mode': self.json_mode}) + return options_dict + + def with_options(self, **kwargs): + """ + Make a copy of this JSONOptions, overriding some options:: + + >>> from bson.json_util import CANONICAL_JSON_OPTIONS + >>> CANONICAL_JSON_OPTIONS.tz_aware + True + >>> json_options = CANONICAL_JSON_OPTIONS.with_options(tz_aware=False) + >>> json_options.tz_aware + False + + .. versionadded:: 3.12 + """ + opts = self._options_dict() + for opt in ('strict_number_long', 'datetime_representation', + 'strict_uuid', 'json_mode'): + opts[opt] = kwargs.get(opt, getattr(self, opt)) + opts.update(kwargs) + return JSONOptions(**opts) + + +LEGACY_JSON_OPTIONS = JSONOptions(json_mode=JSONMode.LEGACY) +""":class:`JSONOptions` for encoding to PyMongo's legacy JSON format. + +.. seealso:: The documentation for :const:`bson.json_util.JSONMode.LEGACY`. + +.. versionadded:: 3.5 +""" + +DEFAULT_JSON_OPTIONS = LEGACY_JSON_OPTIONS +"""The default :class:`JSONOptions` for JSON encoding/decoding. + +The same as :const:`LEGACY_JSON_OPTIONS`. This will change to +:const:`RELAXED_JSON_OPTIONS` in a future release. + +.. versionadded:: 3.4 +""" + +CANONICAL_JSON_OPTIONS = JSONOptions(json_mode=JSONMode.CANONICAL) +""":class:`JSONOptions` for Canonical Extended JSON. + +.. seealso:: The documentation for :const:`bson.json_util.JSONMode.CANONICAL`. + +.. versionadded:: 3.5 +""" + +RELAXED_JSON_OPTIONS = JSONOptions(json_mode=JSONMode.RELAXED) +""":class:`JSONOptions` for Relaxed Extended JSON. + +.. seealso:: The documentation for :const:`bson.json_util.JSONMode.RELAXED`. + +.. versionadded:: 3.5 +""" + +STRICT_JSON_OPTIONS = JSONOptions( + strict_number_long=True, + datetime_representation=DatetimeRepresentation.ISO8601, + strict_uuid=True) +"""**DEPRECATED** - :class:`JSONOptions` for MongoDB Extended JSON's *Strict +mode* encoding. + +.. versionadded:: 3.4 + +.. versionchanged:: 3.5 + Deprecated. Use :const:`RELAXED_JSON_OPTIONS` or + :const:`CANONICAL_JSON_OPTIONS` instead. +""" + + +def dumps(obj, *args, **kwargs): + """Helper function that wraps :func:`json.dumps`. + + Recursive function that handles all BSON types including + :class:`~bson.binary.Binary` and :class:`~bson.code.Code`. + + :Parameters: + - `json_options`: A :class:`JSONOptions` instance used to modify the + encoding of MongoDB Extended JSON types. Defaults to + :const:`DEFAULT_JSON_OPTIONS`. + + .. versionchanged:: 3.4 + Accepts optional parameter `json_options`. See :class:`JSONOptions`. + + .. versionchanged:: 2.7 + Preserves order when rendering SON, Timestamp, Code, Binary, and DBRef + instances. + """ + json_options = kwargs.pop("json_options", DEFAULT_JSON_OPTIONS) + return json.dumps(_json_convert(obj, json_options), *args, **kwargs) + + +def loads(s, *args, **kwargs): + """Helper function that wraps :func:`json.loads`. + + Automatically passes the object_hook for BSON type conversion. + + Raises ``TypeError``, ``ValueError``, ``KeyError``, or + :exc:`~bson.errors.InvalidId` on invalid MongoDB Extended JSON. + + :Parameters: + - `json_options`: A :class:`JSONOptions` instance used to modify the + decoding of MongoDB Extended JSON types. Defaults to + :const:`DEFAULT_JSON_OPTIONS`. + + .. versionchanged:: 3.5 + Parses Relaxed and Canonical Extended JSON as well as PyMongo's legacy + format. Now raises ``TypeError`` or ``ValueError`` when parsing JSON + type wrappers with values of the wrong type or any extra keys. + + .. versionchanged:: 3.4 + Accepts optional parameter `json_options`. See :class:`JSONOptions`. + """ + json_options = kwargs.pop("json_options", DEFAULT_JSON_OPTIONS) + kwargs["object_pairs_hook"] = lambda pairs: object_pairs_hook( + pairs, json_options) + return json.loads(s, *args, **kwargs) + + +def _json_convert(obj, json_options=DEFAULT_JSON_OPTIONS): + """Recursive helper method that converts BSON types so they can be + converted into json. + """ + if hasattr(obj, 'iteritems') or hasattr(obj, 'items'): # PY3 support + return SON(((k, _json_convert(v, json_options)) + for k, v in iteritems(obj))) + elif hasattr(obj, '__iter__') and not isinstance(obj, (text_type, bytes)): + return list((_json_convert(v, json_options) for v in obj)) + try: + return default(obj, json_options) + except TypeError: + return obj + + +def object_pairs_hook(pairs, json_options=DEFAULT_JSON_OPTIONS): + return object_hook(json_options.document_class(pairs), json_options) + + +def object_hook(dct, json_options=DEFAULT_JSON_OPTIONS): + if "$oid" in dct: + return _parse_canonical_oid(dct) + if "$ref" in dct: + return _parse_canonical_dbref(dct) + if "$date" in dct: + return _parse_canonical_datetime(dct, json_options) + if "$regex" in dct: + return _parse_legacy_regex(dct) + if "$minKey" in dct: + return _parse_canonical_minkey(dct) + if "$maxKey" in dct: + return _parse_canonical_maxkey(dct) + if "$binary" in dct: + if "$type" in dct: + return _parse_legacy_binary(dct, json_options) + else: + return _parse_canonical_binary(dct, json_options) + if "$code" in dct: + return _parse_canonical_code(dct) + if "$uuid" in dct: + return _parse_legacy_uuid(dct, json_options) + if "$undefined" in dct: + return None + if "$numberLong" in dct: + return _parse_canonical_int64(dct) + if "$timestamp" in dct: + tsp = dct["$timestamp"] + return Timestamp(tsp["t"], tsp["i"]) + if "$numberDecimal" in dct: + return _parse_canonical_decimal128(dct) + if "$dbPointer" in dct: + return _parse_canonical_dbpointer(dct) + if "$regularExpression" in dct: + return _parse_canonical_regex(dct) + if "$symbol" in dct: + return _parse_canonical_symbol(dct) + if "$numberInt" in dct: + return _parse_canonical_int32(dct) + if "$numberDouble" in dct: + return _parse_canonical_double(dct) + return dct + + +def _parse_legacy_regex(doc): + pattern = doc["$regex"] + # Check if this is the $regex query operator. + if isinstance(pattern, Regex): + return doc + flags = 0 + # PyMongo always adds $options but some other tools may not. + for opt in doc.get("$options", ""): + flags |= _RE_OPT_TABLE.get(opt, 0) + return Regex(pattern, flags) + + +def _parse_legacy_uuid(doc, json_options): + """Decode a JSON legacy $uuid to Python UUID.""" + if len(doc) != 1: + raise TypeError('Bad $uuid, extra field(s): %s' % (doc,)) + if not isinstance(doc["$uuid"], text_type): + raise TypeError('$uuid must be a string: %s' % (doc,)) + if json_options.uuid_representation == UuidRepresentation.UNSPECIFIED: + return Binary.from_uuid(uuid.UUID(doc["$uuid"])) + else: + return uuid.UUID(doc["$uuid"]) + + +def _binary_or_uuid(data, subtype, json_options): + # special handling for UUID + if subtype in ALL_UUID_SUBTYPES: + uuid_representation = json_options.uuid_representation + binary_value = Binary(data, subtype) + if uuid_representation == UuidRepresentation.UNSPECIFIED: + return binary_value + if subtype == UUID_SUBTYPE: + # Legacy behavior: use STANDARD with binary subtype 4. + uuid_representation = UuidRepresentation.STANDARD + elif uuid_representation == UuidRepresentation.STANDARD: + # subtype == OLD_UUID_SUBTYPE + # Legacy behavior: STANDARD is the same as PYTHON_LEGACY. + uuid_representation = UuidRepresentation.PYTHON_LEGACY + return binary_value.as_uuid(uuid_representation) + + if PY3 and subtype == 0: + return data + return Binary(data, subtype) + + +def _parse_legacy_binary(doc, json_options): + if isinstance(doc["$type"], int): + doc["$type"] = "%02x" % doc["$type"] + subtype = int(doc["$type"], 16) + if subtype >= 0xffffff80: # Handle mongoexport values + subtype = int(doc["$type"][6:], 16) + data = base64.b64decode(doc["$binary"].encode()) + return _binary_or_uuid(data, subtype, json_options) + + +def _parse_canonical_binary(doc, json_options): + binary = doc["$binary"] + b64 = binary["base64"] + subtype = binary["subType"] + if not isinstance(b64, string_type): + raise TypeError('$binary base64 must be a string: %s' % (doc,)) + if not isinstance(subtype, string_type) or len(subtype) > 2: + raise TypeError('$binary subType must be a string at most 2 ' + 'characters: %s' % (doc,)) + if len(binary) != 2: + raise TypeError('$binary must include only "base64" and "subType" ' + 'components: %s' % (doc,)) + + data = base64.b64decode(b64.encode()) + return _binary_or_uuid(data, int(subtype, 16), json_options) + + +def _parse_canonical_datetime(doc, json_options): + """Decode a JSON datetime to python datetime.datetime.""" + dtm = doc["$date"] + if len(doc) != 1: + raise TypeError('Bad $date, extra field(s): %s' % (doc,)) + # mongoexport 2.6 and newer + if isinstance(dtm, string_type): + # Parse offset + if dtm[-1] == 'Z': + dt = dtm[:-1] + offset = 'Z' + elif dtm[-6] in ('+', '-') and dtm[-3] == ':': + # (+|-)HH:MM + dt = dtm[:-6] + offset = dtm[-6:] + elif dtm[-5] in ('+', '-'): + # (+|-)HHMM + dt = dtm[:-5] + offset = dtm[-5:] + elif dtm[-3] in ('+', '-'): + # (+|-)HH + dt = dtm[:-3] + offset = dtm[-3:] + else: + dt = dtm + offset = '' + + # Parse the optional factional seconds portion. + dot_index = dt.rfind('.') + microsecond = 0 + if dot_index != -1: + microsecond = int(float(dt[dot_index:]) * 1000000) + dt = dt[:dot_index] + + aware = datetime.datetime.strptime( + dt, "%Y-%m-%dT%H:%M:%S").replace(microsecond=microsecond, + tzinfo=utc) + + if offset and offset != 'Z': + if len(offset) == 6: + hours, minutes = offset[1:].split(':') + secs = (int(hours) * 3600 + int(minutes) * 60) + elif len(offset) == 5: + secs = (int(offset[1:3]) * 3600 + int(offset[3:]) * 60) + elif len(offset) == 3: + secs = int(offset[1:3]) * 3600 + if offset[0] == "-": + secs *= -1 + aware = aware - datetime.timedelta(seconds=secs) + + if json_options.tz_aware: + if json_options.tzinfo: + aware = aware.astimezone(json_options.tzinfo) + return aware + else: + return aware.replace(tzinfo=None) + return bson._millis_to_datetime(int(dtm), json_options) + + +def _parse_canonical_oid(doc): + """Decode a JSON ObjectId to bson.objectid.ObjectId.""" + if len(doc) != 1: + raise TypeError('Bad $oid, extra field(s): %s' % (doc,)) + return ObjectId(doc['$oid']) + + +def _parse_canonical_symbol(doc): + """Decode a JSON symbol to Python string.""" + symbol = doc['$symbol'] + if len(doc) != 1: + raise TypeError('Bad $symbol, extra field(s): %s' % (doc,)) + return text_type(symbol) + + +def _parse_canonical_code(doc): + """Decode a JSON code to bson.code.Code.""" + for key in doc: + if key not in ('$code', '$scope'): + raise TypeError('Bad $code, extra field(s): %s' % (doc,)) + return Code(doc['$code'], scope=doc.get('$scope')) + + +def _parse_canonical_regex(doc): + """Decode a JSON regex to bson.regex.Regex.""" + regex = doc['$regularExpression'] + if len(doc) != 1: + raise TypeError('Bad $regularExpression, extra field(s): %s' % (doc,)) + if len(regex) != 2: + raise TypeError('Bad $regularExpression must include only "pattern"' + 'and "options" components: %s' % (doc,)) + return Regex(regex['pattern'], regex['options']) + + +def _parse_canonical_dbref(doc): + """Decode a JSON DBRef to bson.dbref.DBRef.""" + for key in doc: + if key.startswith('$') and key not in _DBREF_KEYS: + # Other keys start with $, so dct cannot be parsed as a DBRef. + return doc + return DBRef(doc.pop('$ref'), doc.pop('$id'), + database=doc.pop('$db', None), **doc) + + +def _parse_canonical_dbpointer(doc): + """Decode a JSON (deprecated) DBPointer to bson.dbref.DBRef.""" + dbref = doc['$dbPointer'] + if len(doc) != 1: + raise TypeError('Bad $dbPointer, extra field(s): %s' % (doc,)) + if isinstance(dbref, DBRef): + dbref_doc = dbref.as_doc() + # DBPointer must not contain $db in its value. + if dbref.database is not None: + raise TypeError( + 'Bad $dbPointer, extra field $db: %s' % (dbref_doc,)) + if not isinstance(dbref.id, ObjectId): + raise TypeError( + 'Bad $dbPointer, $id must be an ObjectId: %s' % (dbref_doc,)) + if len(dbref_doc) != 2: + raise TypeError( + 'Bad $dbPointer, extra field(s) in DBRef: %s' % (dbref_doc,)) + return dbref + else: + raise TypeError('Bad $dbPointer, expected a DBRef: %s' % (doc,)) + + +def _parse_canonical_int32(doc): + """Decode a JSON int32 to python int.""" + i_str = doc['$numberInt'] + if len(doc) != 1: + raise TypeError('Bad $numberInt, extra field(s): %s' % (doc,)) + if not isinstance(i_str, string_type): + raise TypeError('$numberInt must be string: %s' % (doc,)) + return int(i_str) + + +def _parse_canonical_int64(doc): + """Decode a JSON int64 to bson.int64.Int64.""" + l_str = doc['$numberLong'] + if len(doc) != 1: + raise TypeError('Bad $numberLong, extra field(s): %s' % (doc,)) + return Int64(l_str) + + +def _parse_canonical_double(doc): + """Decode a JSON double to python float.""" + d_str = doc['$numberDouble'] + if len(doc) != 1: + raise TypeError('Bad $numberDouble, extra field(s): %s' % (doc,)) + if not isinstance(d_str, string_type): + raise TypeError('$numberDouble must be string: %s' % (doc,)) + return float(d_str) + + +def _parse_canonical_decimal128(doc): + """Decode a JSON decimal128 to bson.decimal128.Decimal128.""" + d_str = doc['$numberDecimal'] + if len(doc) != 1: + raise TypeError('Bad $numberDecimal, extra field(s): %s' % (doc,)) + if not isinstance(d_str, string_type): + raise TypeError('$numberDecimal must be string: %s' % (doc,)) + return Decimal128(d_str) + + +def _parse_canonical_minkey(doc): + """Decode a JSON MinKey to bson.min_key.MinKey.""" + if type(doc['$minKey']) is not int or doc['$minKey'] != 1: + raise TypeError('$minKey value must be 1: %s' % (doc,)) + if len(doc) != 1: + raise TypeError('Bad $minKey, extra field(s): %s' % (doc,)) + return MinKey() + + +def _parse_canonical_maxkey(doc): + """Decode a JSON MaxKey to bson.max_key.MaxKey.""" + if type(doc['$maxKey']) is not int or doc['$maxKey'] != 1: + raise TypeError('$maxKey value must be 1: %s', (doc,)) + if len(doc) != 1: + raise TypeError('Bad $minKey, extra field(s): %s' % (doc,)) + return MaxKey() + + +def _encode_binary(data, subtype, json_options): + if json_options.json_mode == JSONMode.LEGACY: + return SON([ + ('$binary', base64.b64encode(data).decode()), + ('$type', "%02x" % subtype)]) + return {'$binary': SON([ + ('base64', base64.b64encode(data).decode()), + ('subType', "%02x" % subtype)])} + + +def default(obj, json_options=DEFAULT_JSON_OPTIONS): + # We preserve key order when rendering SON, DBRef, etc. as JSON by + # returning a SON for those types instead of a dict. + if isinstance(obj, ObjectId): + return {"$oid": str(obj)} + if isinstance(obj, DBRef): + return _json_convert(obj.as_doc(), json_options=json_options) + if isinstance(obj, datetime.datetime): + if (json_options.datetime_representation == + DatetimeRepresentation.ISO8601): + if not obj.tzinfo: + obj = obj.replace(tzinfo=utc) + if obj >= EPOCH_AWARE: + off = obj.tzinfo.utcoffset(obj) + if (off.days, off.seconds, off.microseconds) == (0, 0, 0): + tz_string = 'Z' + else: + tz_string = obj.strftime('%z') + millis = int(obj.microsecond / 1000) + fracsecs = ".%03d" % (millis,) if millis else "" + return {"$date": "%s%s%s" % ( + obj.strftime("%Y-%m-%dT%H:%M:%S"), fracsecs, tz_string)} + + millis = bson._datetime_to_millis(obj) + if (json_options.datetime_representation == + DatetimeRepresentation.LEGACY): + return {"$date": millis} + return {"$date": {"$numberLong": str(millis)}} + if json_options.strict_number_long and isinstance(obj, Int64): + return {"$numberLong": str(obj)} + if isinstance(obj, (RE_TYPE, Regex)): + flags = "" + if obj.flags & re.IGNORECASE: + flags += "i" + if obj.flags & re.LOCALE: + flags += "l" + if obj.flags & re.MULTILINE: + flags += "m" + if obj.flags & re.DOTALL: + flags += "s" + if obj.flags & re.UNICODE: + flags += "u" + if obj.flags & re.VERBOSE: + flags += "x" + if isinstance(obj.pattern, text_type): + pattern = obj.pattern + else: + pattern = obj.pattern.decode('utf-8') + if json_options.json_mode == JSONMode.LEGACY: + return SON([("$regex", pattern), ("$options", flags)]) + return {'$regularExpression': SON([("pattern", pattern), + ("options", flags)])} + if isinstance(obj, MinKey): + return {"$minKey": 1} + if isinstance(obj, MaxKey): + return {"$maxKey": 1} + if isinstance(obj, Timestamp): + return {"$timestamp": SON([("t", obj.time), ("i", obj.inc)])} + if isinstance(obj, Code): + if obj.scope is None: + return {'$code': str(obj)} + return SON([ + ('$code', str(obj)), + ('$scope', _json_convert(obj.scope, json_options))]) + if isinstance(obj, Binary): + return _encode_binary(obj, obj.subtype, json_options) + if PY3 and isinstance(obj, bytes): + return _encode_binary(obj, 0, json_options) + if isinstance(obj, uuid.UUID): + if json_options.strict_uuid: + binval = Binary.from_uuid( + obj, uuid_representation=json_options.uuid_representation) + return _encode_binary(binval, binval.subtype, json_options) + else: + return {"$uuid": obj.hex} + if isinstance(obj, Decimal128): + return {"$numberDecimal": str(obj)} + if isinstance(obj, bool): + return obj + if (json_options.json_mode == JSONMode.CANONICAL and + isinstance(obj, integer_types)): + if -2 ** 31 <= obj < 2 ** 31: + return {'$numberInt': text_type(obj)} + return {'$numberLong': text_type(obj)} + if json_options.json_mode != JSONMode.LEGACY and isinstance(obj, float): + if math.isnan(obj): + return {'$numberDouble': 'NaN'} + elif math.isinf(obj): + representation = 'Infinity' if obj > 0 else '-Infinity' + return {'$numberDouble': representation} + elif json_options.json_mode == JSONMode.CANONICAL: + # repr() will return the shortest string guaranteed to produce the + # original value, when float() is called on it. str produces a + # shorter string in Python 2. + return {'$numberDouble': text_type(repr(obj))} + raise TypeError("%r is not JSON serializable" % obj) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/max_key.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/max_key.py new file mode 100644 index 00000000..7e89dd70 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/max_key.py @@ -0,0 +1,50 @@ +# Copyright 2010-present MongoDB, Inc. +# +# 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. + +"""Representation for the MongoDB internal MaxKey type. +""" + + +class MaxKey(object): + """MongoDB internal MaxKey type. + + .. versionchanged:: 2.7 + ``MaxKey`` now implements comparison operators. + """ + + _type_marker = 127 + + def __eq__(self, other): + return isinstance(other, MaxKey) + + def __hash__(self): + return hash(self._type_marker) + + def __ne__(self, other): + return not self == other + + def __le__(self, other): + return isinstance(other, MaxKey) + + def __lt__(self, dummy): + return False + + def __ge__(self, dummy): + return True + + def __gt__(self, other): + return not isinstance(other, MaxKey) + + def __repr__(self): + return "MaxKey()" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/min_key.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/min_key.py new file mode 100644 index 00000000..b03520e9 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/min_key.py @@ -0,0 +1,50 @@ +# Copyright 2010-present MongoDB, Inc. +# +# 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. + +"""Representation for the MongoDB internal MinKey type. +""" + + +class MinKey(object): + """MongoDB internal MinKey type. + + .. versionchanged:: 2.7 + ``MinKey`` now implements comparison operators. + """ + + _type_marker = 255 + + def __eq__(self, other): + return isinstance(other, MinKey) + + def __hash__(self): + return hash(self._type_marker) + + def __ne__(self, other): + return not self == other + + def __le__(self, dummy): + return True + + def __lt__(self, other): + return not isinstance(other, MinKey) + + def __ge__(self, other): + return isinstance(other, MinKey) + + def __gt__(self, dummy): + return False + + def __repr__(self): + return "MinKey()" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/objectid.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/objectid.py new file mode 100644 index 00000000..ae47c437 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/objectid.py @@ -0,0 +1,299 @@ +# Copyright 2009-2015 MongoDB, Inc. +# +# 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. + +"""Tools for working with MongoDB `ObjectIds +`_. +""" + +import binascii +import calendar +import datetime +import os +import struct +import threading +import time + +from random import SystemRandom + +from bson.errors import InvalidId +from bson.py3compat import PY3, bytes_from_hex, string_type, text_type +from bson.tz_util import utc + + +_MAX_COUNTER_VALUE = 0xFFFFFF + + +def _raise_invalid_id(oid): + raise InvalidId( + "%r is not a valid ObjectId, it must be a 12-byte input" + " or a 24-character hex string" % oid) + + +def _random_bytes(): + """Get the 5-byte random field of an ObjectId.""" + return os.urandom(5) + + +class ObjectId(object): + """A MongoDB ObjectId. + """ + + _pid = os.getpid() + + _inc = SystemRandom().randint(0, _MAX_COUNTER_VALUE) + _inc_lock = threading.Lock() + + __random = _random_bytes() + + __slots__ = ('__id',) + + _type_marker = 7 + + def __init__(self, oid=None): + """Initialize a new ObjectId. + + An ObjectId is a 12-byte unique identifier consisting of: + + - a 4-byte value representing the seconds since the Unix epoch, + - a 5-byte random value, + - a 3-byte counter, starting with a random value. + + By default, ``ObjectId()`` creates a new unique identifier. The + optional parameter `oid` can be an :class:`ObjectId`, or any 12 + :class:`bytes` or, in Python 2, any 12-character :class:`str`. + + For example, the 12 bytes b'foo-bar-quux' do not follow the ObjectId + specification but they are acceptable input:: + + >>> ObjectId(b'foo-bar-quux') + ObjectId('666f6f2d6261722d71757578') + + `oid` can also be a :class:`unicode` or :class:`str` of 24 hex digits:: + + >>> ObjectId('0123456789ab0123456789ab') + ObjectId('0123456789ab0123456789ab') + >>> + >>> # A u-prefixed unicode literal: + >>> ObjectId(u'0123456789ab0123456789ab') + ObjectId('0123456789ab0123456789ab') + + Raises :class:`~bson.errors.InvalidId` if `oid` is not 12 bytes nor + 24 hex digits, or :class:`TypeError` if `oid` is not an accepted type. + + :Parameters: + - `oid` (optional): a valid ObjectId. + + .. seealso:: The MongoDB documentation on `ObjectIds`_. + + .. versionchanged:: 3.8 + :class:`~bson.objectid.ObjectId` now implements the `ObjectID + specification version 0.2 + `_. + """ + if oid is None: + self.__generate() + elif isinstance(oid, bytes) and len(oid) == 12: + self.__id = oid + else: + self.__validate(oid) + + @classmethod + def from_datetime(cls, generation_time): + """Create a dummy ObjectId instance with a specific generation time. + + This method is useful for doing range queries on a field + containing :class:`ObjectId` instances. + + .. warning:: + It is not safe to insert a document containing an ObjectId + generated using this method. This method deliberately + eliminates the uniqueness guarantee that ObjectIds + generally provide. ObjectIds generated with this method + should be used exclusively in queries. + + `generation_time` will be converted to UTC. Naive datetime + instances will be treated as though they already contain UTC. + + An example using this helper to get documents where ``"_id"`` + was generated before January 1, 2010 would be: + + >>> gen_time = datetime.datetime(2010, 1, 1) + >>> dummy_id = ObjectId.from_datetime(gen_time) + >>> result = collection.find({"_id": {"$lt": dummy_id}}) + + :Parameters: + - `generation_time`: :class:`~datetime.datetime` to be used + as the generation time for the resulting ObjectId. + """ + if generation_time.utcoffset() is not None: + generation_time = generation_time - generation_time.utcoffset() + timestamp = calendar.timegm(generation_time.timetuple()) + oid = struct.pack( + ">I", int(timestamp)) + b"\x00\x00\x00\x00\x00\x00\x00\x00" + return cls(oid) + + @classmethod + def is_valid(cls, oid): + """Checks if a `oid` string is valid or not. + + :Parameters: + - `oid`: the object id to validate + + .. versionadded:: 2.3 + """ + if not oid: + return False + + try: + ObjectId(oid) + return True + except (InvalidId, TypeError): + return False + + @classmethod + def _random(cls): + """Generate a 5-byte random number once per process. + """ + pid = os.getpid() + if pid != cls._pid: + cls._pid = pid + cls.__random = _random_bytes() + return cls.__random + + def __generate(self): + """Generate a new value for this ObjectId. + """ + + # 4 bytes current time + oid = struct.pack(">I", int(time.time())) + + # 5 bytes random + oid += ObjectId._random() + + # 3 bytes inc + with ObjectId._inc_lock: + oid += struct.pack(">I", ObjectId._inc)[1:4] + ObjectId._inc = (ObjectId._inc + 1) % (_MAX_COUNTER_VALUE + 1) + + self.__id = oid + + def __validate(self, oid): + """Validate and use the given id for this ObjectId. + + Raises TypeError if id is not an instance of + (:class:`basestring` (:class:`str` or :class:`bytes` + in python 3), ObjectId) and InvalidId if it is not a + valid ObjectId. + + :Parameters: + - `oid`: a valid ObjectId + """ + if isinstance(oid, ObjectId): + self.__id = oid.binary + # bytes or unicode in python 2, str in python 3 + elif isinstance(oid, string_type): + if len(oid) == 24: + try: + self.__id = bytes_from_hex(oid) + except (TypeError, ValueError): + _raise_invalid_id(oid) + else: + _raise_invalid_id(oid) + else: + raise TypeError("id must be an instance of (bytes, %s, ObjectId), " + "not %s" % (text_type.__name__, type(oid))) + + @property + def binary(self): + """12-byte binary representation of this ObjectId. + """ + return self.__id + + @property + def generation_time(self): + """A :class:`datetime.datetime` instance representing the time of + generation for this :class:`ObjectId`. + + The :class:`datetime.datetime` is timezone aware, and + represents the generation time in UTC. It is precise to the + second. + """ + timestamp = struct.unpack(">I", self.__id[0:4])[0] + return datetime.datetime.fromtimestamp(timestamp, utc) + + def __getstate__(self): + """return value of object for pickling. + needed explicitly because __slots__() defined. + """ + return self.__id + + def __setstate__(self, value): + """explicit state set from pickling + """ + # Provide backwards compatability with OIDs + # pickled with pymongo-1.9 or older. + if isinstance(value, dict): + oid = value["_ObjectId__id"] + else: + oid = value + # ObjectIds pickled in python 2.x used `str` for __id. + # In python 3.x this has to be converted to `bytes` + # by encoding latin-1. + if PY3 and isinstance(oid, text_type): + self.__id = oid.encode('latin-1') + else: + self.__id = oid + + def __str__(self): + if PY3: + return binascii.hexlify(self.__id).decode() + return binascii.hexlify(self.__id) + + def __repr__(self): + return "ObjectId('%s')" % (str(self),) + + def __eq__(self, other): + if isinstance(other, ObjectId): + return self.__id == other.binary + return NotImplemented + + def __ne__(self, other): + if isinstance(other, ObjectId): + return self.__id != other.binary + return NotImplemented + + def __lt__(self, other): + if isinstance(other, ObjectId): + return self.__id < other.binary + return NotImplemented + + def __le__(self, other): + if isinstance(other, ObjectId): + return self.__id <= other.binary + return NotImplemented + + def __gt__(self, other): + if isinstance(other, ObjectId): + return self.__id > other.binary + return NotImplemented + + def __ge__(self, other): + if isinstance(other, ObjectId): + return self.__id >= other.binary + return NotImplemented + + def __hash__(self): + """Get a hash value for this :class:`ObjectId`.""" + return hash(self.__id) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/py3compat.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/py3compat.py new file mode 100644 index 00000000..84d1ea00 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/py3compat.py @@ -0,0 +1,107 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""Utility functions and definitions for python3 compatibility.""" + +import sys + +PY3 = sys.version_info[0] == 3 + +if PY3: + import codecs + import collections.abc as abc + import _thread as thread + from abc import ABC, abstractmethod + from io import BytesIO as StringIO + + def abstractproperty(func): + return property(abstractmethod(func)) + + MAXSIZE = sys.maxsize + + imap = map + + def b(s): + # BSON and socket operations deal in binary data. In + # python 3 that means instances of `bytes`. In python + # 2.7 you can create an alias for `bytes` using + # the b prefix (e.g. b'foo'). + # See http://python3porting.com/problems.html#nicer-solutions + return codecs.latin_1_encode(s)[0] + + def bytes_from_hex(h): + return bytes.fromhex(h) + + def iteritems(d): + return iter(d.items()) + + def itervalues(d): + return iter(d.values()) + + def reraise(exctype, value, trace=None): + raise exctype(str(value)).with_traceback(trace) + + def reraise_instance(exc_instance, trace=None): + raise exc_instance.with_traceback(trace) + + def _unicode(s): + return s + + text_type = str + string_type = str + integer_types = int +else: + import collections as abc + import thread + from abc import ABCMeta, abstractproperty + + from itertools import imap + try: + from cStringIO import StringIO + except ImportError: + from StringIO import StringIO + + ABC = ABCMeta('ABC', (object,), {}) + + MAXSIZE = sys.maxint + + def b(s): + # See comments above. In python 2.x b('foo') is just 'foo'. + return s + + def bytes_from_hex(h): + return h.decode('hex') + + def iteritems(d): + return d.iteritems() + + def itervalues(d): + return d.itervalues() + + def reraise(exctype, value, trace=None): + _reraise(exctype, str(value), trace) + + def reraise_instance(exc_instance, trace=None): + _reraise(exc_instance, None, trace) + + # "raise x, y, z" raises SyntaxError in Python 3 + exec("""def _reraise(exc, value, trace): + raise exc, value, trace +""") + + _unicode = unicode + + string_type = basestring + text_type = unicode + integer_types = (int, long) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/raw_bson.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/raw_bson.py new file mode 100644 index 00000000..78d0aee5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/raw_bson.py @@ -0,0 +1,176 @@ +# Copyright 2015-present MongoDB, Inc. +# +# 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. + +"""Tools for representing raw BSON documents. + +Inserting and Retrieving RawBSONDocuments +========================================= + +Example: Moving a document between different databases/collections + +.. doctest:: + + >>> import bson + >>> from pymongo import MongoClient + >>> from bson.raw_bson import RawBSONDocument + >>> client = MongoClient(document_class=RawBSONDocument) + >>> client.drop_database('db') + >>> client.drop_database('replica_db') + >>> db = client.db + >>> result = db.test.insert_many([{'a': 1}, + ... {'b': 1}, + ... {'c': 1}, + ... {'d': 1}]) + >>> replica_db = client.replica_db + >>> for doc in db.test.find(): + ... print("raw document: %r" % (doc.raw,)) + ... result = replica_db.test.insert_one(doc) + raw document: '...' + raw document: '...' + raw document: '...' + raw document: '...' + >>> for doc in replica_db.test.find(projection={'_id': 0}): + ... print("decoded document: %r" % (bson.decode(doc.raw),)) + decoded document: {u'a': 1} + decoded document: {u'b': 1} + decoded document: {u'c': 1} + decoded document: {u'd': 1} + +For use cases like moving documents across different databases or writing binary +blobs to disk, using raw BSON documents provides better speed and avoids the +overhead of decoding or encoding BSON. +""" + +from bson import _raw_to_dict, _get_object_size +from bson.py3compat import abc, iteritems +from bson.codec_options import ( + DEFAULT_CODEC_OPTIONS as DEFAULT, _RAW_BSON_DOCUMENT_MARKER) +from bson.son import SON + + +class RawBSONDocument(abc.Mapping): + """Representation for a MongoDB document that provides access to the raw + BSON bytes that compose it. + + Only when a field is accessed or modified within the document does + RawBSONDocument decode its bytes. + """ + + __slots__ = ('__raw', '__inflated_doc', '__codec_options') + _type_marker = _RAW_BSON_DOCUMENT_MARKER + + def __init__(self, bson_bytes, codec_options=None): + """Create a new :class:`RawBSONDocument` + + :class:`RawBSONDocument` is a representation of a BSON document that + provides access to the underlying raw BSON bytes. Only when a field is + accessed or modified within the document does RawBSONDocument decode + its bytes. + + :class:`RawBSONDocument` implements the ``Mapping`` abstract base + class from the standard library so it can be used like a read-only + ``dict``:: + + >>> from bson import encode + >>> raw_doc = RawBSONDocument(encode({'_id': 'my_doc'})) + >>> raw_doc.raw + b'...' + >>> raw_doc['_id'] + 'my_doc' + + :Parameters: + - `bson_bytes`: the BSON bytes that compose this document + - `codec_options` (optional): An instance of + :class:`~bson.codec_options.CodecOptions` whose ``document_class`` + must be :class:`RawBSONDocument`. The default is + :attr:`DEFAULT_RAW_BSON_OPTIONS`. + + .. versionchanged:: 3.8 + :class:`RawBSONDocument` now validates that the ``bson_bytes`` + passed in represent a single bson document. + + .. versionchanged:: 3.5 + If a :class:`~bson.codec_options.CodecOptions` is passed in, its + `document_class` must be :class:`RawBSONDocument`. + """ + self.__raw = bson_bytes + self.__inflated_doc = None + # Can't default codec_options to DEFAULT_RAW_BSON_OPTIONS in signature, + # it refers to this class RawBSONDocument. + if codec_options is None: + codec_options = DEFAULT_RAW_BSON_OPTIONS + elif codec_options.document_class is not RawBSONDocument: + raise TypeError( + "RawBSONDocument cannot use CodecOptions with document " + "class %s" % (codec_options.document_class, )) + self.__codec_options = codec_options + # Validate the bson object size. + _get_object_size(bson_bytes, 0, len(bson_bytes)) + + @property + def raw(self): + """The raw BSON bytes composing this document.""" + return self.__raw + + def items(self): + """Lazily decode and iterate elements in this document.""" + return iteritems(self.__inflated) + + @property + def __inflated(self): + if self.__inflated_doc is None: + # We already validated the object's size when this document was + # created, so no need to do that again. + # Use SON to preserve ordering of elements. + self.__inflated_doc = _inflate_bson( + self.__raw, self.__codec_options) + return self.__inflated_doc + + def __getitem__(self, item): + return self.__inflated[item] + + def __iter__(self): + return iter(self.__inflated) + + def __len__(self): + return len(self.__inflated) + + def __eq__(self, other): + if isinstance(other, RawBSONDocument): + return self.__raw == other.raw + return NotImplemented + + def __repr__(self): + return ("RawBSONDocument(%r, codec_options=%r)" + % (self.raw, self.__codec_options)) + + +def _inflate_bson(bson_bytes, codec_options): + """Inflates the top level fields of a BSON document. + + :Parameters: + - `bson_bytes`: the BSON bytes that compose this document + - `codec_options`: An instance of + :class:`~bson.codec_options.CodecOptions` whose ``document_class`` + must be :class:`RawBSONDocument`. + """ + # Use SON to preserve ordering of elements. + return _raw_to_dict( + bson_bytes, 4, len(bson_bytes)-1, codec_options, SON()) + + +DEFAULT_RAW_BSON_OPTIONS = DEFAULT.with_options(document_class=RawBSONDocument) +"""The default :class:`~bson.codec_options.CodecOptions` for +:class:`RawBSONDocument`. +""" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/regex.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/regex.py new file mode 100644 index 00000000..f9d39ad8 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/regex.py @@ -0,0 +1,128 @@ +# Copyright 2013-present MongoDB, Inc. +# +# 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. + +"""Tools for representing MongoDB regular expressions. +""" + +import re + +from bson.son import RE_TYPE +from bson.py3compat import string_type, text_type + + +def str_flags_to_int(str_flags): + flags = 0 + if "i" in str_flags: + flags |= re.IGNORECASE + if "l" in str_flags: + flags |= re.LOCALE + if "m" in str_flags: + flags |= re.MULTILINE + if "s" in str_flags: + flags |= re.DOTALL + if "u" in str_flags: + flags |= re.UNICODE + if "x" in str_flags: + flags |= re.VERBOSE + + return flags + + +class Regex(object): + """BSON regular expression data.""" + _type_marker = 11 + + @classmethod + def from_native(cls, regex): + """Convert a Python regular expression into a ``Regex`` instance. + + Note that in Python 3, a regular expression compiled from a + :class:`str` has the ``re.UNICODE`` flag set. If it is undesirable + to store this flag in a BSON regular expression, unset it first:: + + >>> pattern = re.compile('.*') + >>> regex = Regex.from_native(pattern) + >>> regex.flags ^= re.UNICODE + >>> db.collection.insert({'pattern': regex}) + + :Parameters: + - `regex`: A regular expression object from ``re.compile()``. + + .. warning:: + Python regular expressions use a different syntax and different + set of flags than MongoDB, which uses `PCRE`_. A regular + expression retrieved from the server may not compile in + Python, or may match a different set of strings in Python than + when used in a MongoDB query. + + .. _PCRE: http://www.pcre.org/ + """ + if not isinstance(regex, RE_TYPE): + raise TypeError( + "regex must be a compiled regular expression, not %s" + % type(regex)) + + return Regex(regex.pattern, regex.flags) + + def __init__(self, pattern, flags=0): + """BSON regular expression data. + + This class is useful to store and retrieve regular expressions that are + incompatible with Python's regular expression dialect. + + :Parameters: + - `pattern`: string + - `flags`: (optional) an integer bitmask, or a string of flag + characters like "im" for IGNORECASE and MULTILINE + """ + if not isinstance(pattern, (text_type, bytes)): + raise TypeError("pattern must be a string, not %s" % type(pattern)) + self.pattern = pattern + + if isinstance(flags, string_type): + self.flags = str_flags_to_int(flags) + elif isinstance(flags, int): + self.flags = flags + else: + raise TypeError( + "flags must be a string or int, not %s" % type(flags)) + + def __eq__(self, other): + if isinstance(other, Regex): + return self.pattern == other.pattern and self.flags == other.flags + else: + return NotImplemented + + __hash__ = None + + def __ne__(self, other): + return not self == other + + def __repr__(self): + return "Regex(%r, %r)" % (self.pattern, self.flags) + + def try_compile(self): + """Compile this :class:`Regex` as a Python regular expression. + + .. warning:: + Python regular expressions use a different syntax and different + set of flags than MongoDB, which uses `PCRE`_. A regular + expression retrieved from the server may not compile in + Python, or may match a different set of strings in Python than + when used in a MongoDB query. :meth:`try_compile()` may raise + :exc:`re.error`. + + .. _PCRE: http://www.pcre.org/ + """ + return re.compile(self.pattern, self.flags) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/son.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/son.py new file mode 100644 index 00000000..701cb231 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/son.py @@ -0,0 +1,200 @@ +# Copyright 2009-present MongoDB, Inc. +# +# 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. + +"""Tools for creating and manipulating SON, the Serialized Ocument Notation. + +Regular dictionaries can be used instead of SON objects, but not when the order +of keys is important. A SON object can be used just like a normal Python +dictionary.""" + +import copy +import re + +from bson.py3compat import abc, iteritems + + +# This sort of sucks, but seems to be as good as it gets... +# This is essentially the same as re._pattern_type +RE_TYPE = type(re.compile("")) + + +class SON(dict): + """SON data. + + A subclass of dict that maintains ordering of keys and provides a + few extra niceties for dealing with SON. SON provides an API + similar to collections.OrderedDict from Python 2.7+. + """ + + def __init__(self, data=None, **kwargs): + self.__keys = [] + dict.__init__(self) + self.update(data) + self.update(kwargs) + + def __new__(cls, *args, **kwargs): + instance = super(SON, cls).__new__(cls, *args, **kwargs) + instance.__keys = [] + return instance + + def __repr__(self): + result = [] + for key in self.__keys: + result.append("(%r, %r)" % (key, self[key])) + return "SON([%s])" % ", ".join(result) + + def __setitem__(self, key, value): + if key not in self.__keys: + self.__keys.append(key) + dict.__setitem__(self, key, value) + + def __delitem__(self, key): + self.__keys.remove(key) + dict.__delitem__(self, key) + + def keys(self): + return list(self.__keys) + + def copy(self): + other = SON() + other.update(self) + return other + + # TODO this is all from UserDict.DictMixin. it could probably be made more + # efficient. + # second level definitions support higher levels + def __iter__(self): + for k in self.__keys: + yield k + + def has_key(self, key): + return key in self.__keys + + # third level takes advantage of second level definitions + def iteritems(self): + for k in self: + yield (k, self[k]) + + def iterkeys(self): + return self.__iter__() + + # fourth level uses definitions from lower levels + def itervalues(self): + for _, v in self.iteritems(): + yield v + + def values(self): + return [v for _, v in self.iteritems()] + + def items(self): + return [(key, self[key]) for key in self] + + def clear(self): + self.__keys = [] + super(SON, self).clear() + + def setdefault(self, key, default=None): + try: + return self[key] + except KeyError: + self[key] = default + return default + + def pop(self, key, *args): + if len(args) > 1: + raise TypeError("pop expected at most 2 arguments, got "\ + + repr(1 + len(args))) + try: + value = self[key] + except KeyError: + if args: + return args[0] + raise + del self[key] + return value + + def popitem(self): + try: + k, v = next(self.iteritems()) + except StopIteration: + raise KeyError('container is empty') + del self[k] + return (k, v) + + def update(self, other=None, **kwargs): + # Make progressively weaker assumptions about "other" + if other is None: + pass + elif hasattr(other, 'iteritems'): # iteritems saves memory and lookups + for k, v in other.iteritems(): + self[k] = v + elif hasattr(other, 'keys'): + for k in other.keys(): + self[k] = other[k] + else: + for k, v in other: + self[k] = v + if kwargs: + self.update(kwargs) + + def get(self, key, default=None): + try: + return self[key] + except KeyError: + return default + + def __eq__(self, other): + """Comparison to another SON is order-sensitive while comparison to a + regular dictionary is order-insensitive. + """ + if isinstance(other, SON): + return len(self) == len(other) and self.items() == other.items() + return self.to_dict() == other + + def __ne__(self, other): + return not self == other + + def __len__(self): + return len(self.__keys) + + def to_dict(self): + """Convert a SON document to a normal Python dictionary instance. + + This is trickier than just *dict(...)* because it needs to be + recursive. + """ + + def transform_value(value): + if isinstance(value, list): + return [transform_value(v) for v in value] + elif isinstance(value, abc.Mapping): + return dict([ + (k, transform_value(v)) + for k, v in iteritems(value)]) + else: + return value + + return transform_value(dict(self)) + + def __deepcopy__(self, memo): + out = SON() + val_id = id(self) + if val_id in memo: + return memo.get(val_id) + memo[val_id] = out + for k, v in self.iteritems(): + if not isinstance(v, RE_TYPE): + v = copy.deepcopy(v, memo) + out[k] = v + return out diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/timestamp.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/timestamp.py new file mode 100644 index 00000000..7ea75511 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/timestamp.py @@ -0,0 +1,120 @@ +# Copyright 2010-2015 MongoDB, Inc. +# +# 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. + +"""Tools for representing MongoDB internal Timestamps. +""" + +import calendar +import datetime + +from bson.py3compat import integer_types +from bson.tz_util import utc + +UPPERBOUND = 4294967296 + + +class Timestamp(object): + """MongoDB internal timestamps used in the opLog. + """ + + _type_marker = 17 + + def __init__(self, time, inc): + """Create a new :class:`Timestamp`. + + This class is only for use with the MongoDB opLog. If you need + to store a regular timestamp, please use a + :class:`~datetime.datetime`. + + Raises :class:`TypeError` if `time` is not an instance of + :class: `int` or :class:`~datetime.datetime`, or `inc` is not + an instance of :class:`int`. Raises :class:`ValueError` if + `time` or `inc` is not in [0, 2**32). + + :Parameters: + - `time`: time in seconds since epoch UTC, or a naive UTC + :class:`~datetime.datetime`, or an aware + :class:`~datetime.datetime` + - `inc`: the incrementing counter + """ + if isinstance(time, datetime.datetime): + if time.utcoffset() is not None: + time = time - time.utcoffset() + time = int(calendar.timegm(time.timetuple())) + if not isinstance(time, integer_types): + raise TypeError("time must be an instance of int") + if not isinstance(inc, integer_types): + raise TypeError("inc must be an instance of int") + if not 0 <= time < UPPERBOUND: + raise ValueError("time must be contained in [0, 2**32)") + if not 0 <= inc < UPPERBOUND: + raise ValueError("inc must be contained in [0, 2**32)") + + self.__time = time + self.__inc = inc + + @property + def time(self): + """Get the time portion of this :class:`Timestamp`. + """ + return self.__time + + @property + def inc(self): + """Get the inc portion of this :class:`Timestamp`. + """ + return self.__inc + + def __eq__(self, other): + if isinstance(other, Timestamp): + return (self.__time == other.time and self.__inc == other.inc) + else: + return NotImplemented + + def __hash__(self): + return hash(self.time) ^ hash(self.inc) + + def __ne__(self, other): + return not self == other + + def __lt__(self, other): + if isinstance(other, Timestamp): + return (self.time, self.inc) < (other.time, other.inc) + return NotImplemented + + def __le__(self, other): + if isinstance(other, Timestamp): + return (self.time, self.inc) <= (other.time, other.inc) + return NotImplemented + + def __gt__(self, other): + if isinstance(other, Timestamp): + return (self.time, self.inc) > (other.time, other.inc) + return NotImplemented + + def __ge__(self, other): + if isinstance(other, Timestamp): + return (self.time, self.inc) >= (other.time, other.inc) + return NotImplemented + + def __repr__(self): + return "Timestamp(%s, %s)" % (self.__time, self.__inc) + + def as_datetime(self): + """Return a :class:`~datetime.datetime` instance corresponding + to the time portion of this :class:`Timestamp`. + + The returned datetime's timezone is UTC. + """ + return datetime.datetime.fromtimestamp(self.__time, utc) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/tz_util.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/tz_util.py new file mode 100644 index 00000000..6ec918fb --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/bson/tz_util.py @@ -0,0 +1,52 @@ +# Copyright 2010-2015 MongoDB, Inc. +# +# 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. + +"""Timezone related utilities for BSON.""" + +from datetime import (timedelta, + tzinfo) + +ZERO = timedelta(0) + + +class FixedOffset(tzinfo): + """Fixed offset timezone, in minutes east from UTC. + + Implementation based from the Python `standard library documentation + `_. + Defining __getinitargs__ enables pickling / copying. + """ + + def __init__(self, offset, name): + if isinstance(offset, timedelta): + self.__offset = offset + else: + self.__offset = timedelta(minutes=offset) + self.__name = name + + def __getinitargs__(self): + return self.__offset, self.__name + + def utcoffset(self, dt): + return self.__offset + + def tzname(self, dt): + return self.__name + + def dst(self, dt): + return ZERO + + +utc = FixedOffset(0, "UTC") +"""Fixed offset timezone representing UTC.""" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/LICENSE b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/LICENSE new file mode 100644 index 00000000..c2fda9a2 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/LICENSE @@ -0,0 +1,21 @@ +This package contains a modified version of ca-bundle.crt: + +ca-bundle.crt -- Bundle of CA Root Certificates + +Certificate data from Mozilla as of: Thu Nov 3 19:04:19 2011# +This is a bundle of X.509 certificates of public Certificate Authorities +(CA). These were automatically extracted from Mozilla's root certificates +file (certdata.txt). This file can be found in the mozilla source tree: +http://mxr.mozilla.org/mozilla/source/security/nss/lib/ckfw/builtins/certdata.txt?raw=1# +It contains the certificates in PEM format and therefore +can be directly used with curl / libcurl / php_curl, or with +an Apache+mod_ssl webserver for SSL client authentication. +Just configure this file as the SSLCACertificateFile.# + +***** BEGIN LICENSE BLOCK ***** +This Source Code Form is subject to the terms of the Mozilla Public License, +v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain +one at http://mozilla.org/MPL/2.0/. + +***** END LICENSE BLOCK ***** +@(#) $RCSfile: certdata.txt,v $ $Revision: 1.80 $ $Date: 2011/11/03 15:11:58 $ diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/METADATA new file mode 100644 index 00000000..7a6860db --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/METADATA @@ -0,0 +1,83 @@ +Metadata-Version: 2.1 +Name: certifi +Version: 2021.10.8 +Summary: Python package for providing Mozilla's CA Bundle. +Home-page: https://certifiio.readthedocs.io/en/latest/ +Author: Kenneth Reitz +Author-email: me@kennethreitz.com +License: MPL-2.0 +Project-URL: Documentation, https://certifiio.readthedocs.io/en/latest/ +Project-URL: Source, https://github.com/certifi/python-certifi +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: Mozilla Public License 2.0 (MPL 2.0) +Classifier: Natural Language :: English +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.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 :: 3.8 +Classifier: Programming Language :: Python :: 3.9 + +Certifi: Python SSL Certificates +================================ + +`Certifi`_ provides Mozilla's carefully curated collection of Root Certificates for +validating the trustworthiness of SSL certificates while verifying the identity +of TLS hosts. It has been extracted from the `Requests`_ project. + +Installation +------------ + +``certifi`` is available on PyPI. Simply install it with ``pip``:: + + $ pip install certifi + +Usage +----- + +To reference the installed certificate authority (CA) bundle, you can use the +built-in function:: + + >>> import certifi + + >>> certifi.where() + '/usr/local/lib/python3.7/site-packages/certifi/cacert.pem' + +Or from the command line:: + + $ python -m certifi + /usr/local/lib/python3.7/site-packages/certifi/cacert.pem + +Enjoy! + +1024-bit Root Certificates +~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Browsers and certificate authorities have concluded that 1024-bit keys are +unacceptably weak for certificates, particularly root certificates. For this +reason, Mozilla has removed any weak (i.e. 1024-bit key) certificate from its +bundle, replacing it with an equivalent strong (i.e. 2048-bit or greater key) +certificate from the same CA. Because Mozilla removed these certificates from +its bundle, ``certifi`` removed them as well. + +In previous versions, ``certifi`` provided the ``certifi.old_where()`` function +to intentionally re-add the 1024-bit roots back into your bundle. This was not +recommended in production and therefore was removed at the end of 2018. + +.. _`Certifi`: https://certifiio.readthedocs.io/en/latest/ +.. _`Requests`: https://requests.readthedocs.io/en/master/ + +Addition/Removal of Certificates +-------------------------------- + +Certifi does not support any addition/removal or other modification of the +CA trust store content. This project is intended to provide a reliable and +highly portable root of trust to python deployments. Look to upstream projects +for methods to use alternate trust. + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/RECORD new file mode 100644 index 00000000..824d4f82 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/RECORD @@ -0,0 +1,13 @@ +certifi-2021.10.8.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +certifi-2021.10.8.dist-info/LICENSE,sha256=vp2C82ES-Hp_HXTs1Ih-FGe7roh4qEAEoAEXseR1o-I,1049 +certifi-2021.10.8.dist-info/METADATA,sha256=iB_zbT1uX_8_NC7iGv0YEB-9b3idhQwHrFTSq8R1kD8,2994 +certifi-2021.10.8.dist-info/RECORD,, +certifi-2021.10.8.dist-info/WHEEL,sha256=ADKeyaGyKF5DwBNE0sRE5pvW-bSkFMJfBuhzZ3rceP4,110 +certifi-2021.10.8.dist-info/top_level.txt,sha256=KMu4vUCfsjLrkPbSNdgdekS-pVJzBAJFO__nI8NF6-U,8 +certifi/__init__.py,sha256=xWdRgntT3j1V95zkRipGOg_A1UfEju2FcpujhysZLRI,62 +certifi/__main__.py,sha256=xBBoj905TUWBLRGANOcf7oi6e-3dMP4cEoG9OyMs11g,243 +certifi/__pycache__/__init__.cpython-39.pyc,, +certifi/__pycache__/__main__.cpython-39.pyc,, +certifi/__pycache__/core.cpython-39.pyc,, +certifi/cacert.pem,sha256=-og4Keu4zSpgL5shwfhd4kz0eUnVILzrGCi0zRy2kGw,265969 +certifi/core.py,sha256=V0uyxKOYdz6ulDSusclrLmjbPgOXsD0BnEf0SQ7OnoE,2303 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/WHEEL new file mode 100644 index 00000000..6d38aa06 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.35.1) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/top_level.txt new file mode 100644 index 00000000..963eac53 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi-2021.10.8.dist-info/top_level.txt @@ -0,0 +1 @@ +certifi diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__init__.py new file mode 100644 index 00000000..8db1a0e5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__init__.py @@ -0,0 +1,3 @@ +from .core import contents, where + +__version__ = "2021.10.08" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__main__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__main__.py new file mode 100644 index 00000000..8945b5da --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__main__.py @@ -0,0 +1,12 @@ +import argparse + +from certifi import contents, where + +parser = argparse.ArgumentParser() +parser.add_argument("-c", "--contents", action="store_true") +args = parser.parse_args() + +if args.contents: + print(contents()) +else: + print(where()) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..aa18f5feff85670de03b70aca174f7989b531808 GIT binary patch literal 232 zcmYe~<>g`kf``AV677KWV-N=!FabFZKwK;VBvKes7;_kM8KW3;nWC5&8B&;{m{XX8 z88lg5G6JPFnQn0;=jWBA=9LuRVlB@|ElRE8GBPkS)H5{DGqCW}WVywXoL`h$1TwUU z8A#mXj*l-(Eh^5;&x?;=$xy@wk^m9EEK{sv(sN4Fb5dgpD$7#y%8d0aV|+4`Vu~|M zQgsUwld}`kQ;TDgQ;SM6(=zqr<1_OzOXB183My}L*yQG?l;)(`f!tIKvP*yo0MWZT Avj6}9 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__main__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/__pycache__/__main__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6e69c140359b80672e93c1e074ed066464578ba7 GIT binary patch literal 397 zcmYk0u};G<5Qc51NlnyNyhetUfvE@~SP?=cnc|%Oh zY@M(JLY(CP?*D!MWHz0~$kqFP!@gYq@aBJo&YZiW@0@VNag8$HNsSwlktWCji~#LM zuP6&4Tt+~acpNz^4A0NJ7~#z@9)4t{2iZ&5P-baZr`5KGHe8jwcY z@c9uGY)D#e;xzq>V{KXmg;6~u*hZ{0qLoQ(DN|L)lmB2K2h)o5pcb)&f`SCmKy3&t+nq_Wb+a4ZOsXxd zm-Jfv7n)=LrMZbG|Ak)k%_gx`e9JuE%$uF}ecyZ0(vnZmzF!_izdS;I*v)mrGx7?T z+CwKuhX^WIN;~vu6(c8QL#M-sZpWoWu&9KqEVyt_NypnE*(xWpa@eNCexfGI!aJoM zS5#&Bkau(n}hnL;vd^^ZoW9QNb`5<5UJ9^%yc0=z$E9 zOz9|1Bc0?~kmm6$$a_H?*_Rq4ISg_L60L$b&$P_6YWP2q4r$ey;iE_oOa){lLM^}O z*e0%YHD?uu!w0#vvWQr6B=O_88|Ido-?@guOQT2Qwy70&F%N? z@ZDDXwek8=heh$~;=I}ZXdI=%RKgHpN(jRX0#&SAxXTUkyxUL5{Zw{GhX*n{c-nZ@ zeVgocRifqNQ51iQ`cif0)z{)2B#LO<&jShahUH+}Nj$IW(;9;%jEx(qI7wp5a$y_; zd$C}>iGe1XPO$UGOt3TO+ualA*g0oYvO^f^!SS0o6uCbksN8H)N)JfV!~LOihT vhLUx~P*mR(zib2KP`v$rB%8CAy>#$LbsHTod5qB&#wlmDdo|ZDEth@+;)(XB literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/cacert.pem b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/cacert.pem new file mode 100644 index 00000000..6d0ccc0d --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/cacert.pem @@ -0,0 +1,4362 @@ + +# 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=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=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=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 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=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: 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=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----- +MIIFujCCA6KgAwIBAgIJALtAHEP1Xk+wMA0GCSqGSIb3DQEBBQUAMEUxCzAJBgNV +BAYTAkNIMRUwEwYDVQQKEwxTd2lzc1NpZ24gQUcxHzAdBgNVBAMTFlN3aXNzU2ln +biBHb2xkIENBIC0gRzIwHhcNMDYxMDI1MDgzMDM1WhcNMzYxMDI1MDgzMDM1WjBF +MQswCQYDVQQGEwJDSDEVMBMGA1UEChMMU3dpc3NTaWduIEFHMR8wHQYDVQQDExZT +d2lzc1NpZ24gR29sZCBDQSAtIEcyMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC +CgKCAgEAr+TufoskDhJuqVAtFkQ7kpJcyrhdhJJCEyq8ZVeCQD5XJM1QiyUqt2/8 +76LQwB8CJEoTlo8jE+YoWACjR8cGp4QjK7u9lit/VcyLwVcfDmJlD909Vopz2q5+ +bbqBHH5CjCA12UNNhPqE21Is8w4ndwtrvxEvcnifLtg+5hg3Wipy+dpikJKVyh+c +6bM8K8vzARO/Ws/BtQpgvd21mWRTuKCWs2/iJneRjOBiEAKfNA+k1ZIzUd6+jbqE +emA8atufK+ze3gE/bk3lUIbLtK/tREDFylqM2tIrfKjuvqblCqoOpd8FUrdVxyJd +MmqXl2MT28nbeTZ7hTpKxVKJ+STnnXepgv9VHKVxaSvRAiTysybUa9oEVeXBCsdt +MDeQKuSeFDNeFhdVxVu1yzSJkvGdJo+hB9TGsnhQ2wwMC3wLjEHXuendjIj3o02y +MszYF9rNt85mndT9Xv+9lz4pded+p2JYryU0pUHHPbwNUMoDAw8IWh+Vc3hiv69y +FGkOpeUDDniOJihC8AcLYiAQZzlG+qkDzAQ4embvIIO1jEpWjpEA/I5cgt6IoMPi +aG59je883WX0XaxR7ySArqpWl2/5rX3aYT+YdzylkbYcjCbaZaIJbcHiVOO5ykxM +gI93e2CaHt+28kgeDrpOVG2Y4OGiGqJ3UM/EY5LsRxmd6+ZrzsECAwEAAaOBrDCB +qTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUWyV7 +lqRlUX64OfPAeGZe6Drn8O4wHwYDVR0jBBgwFoAUWyV7lqRlUX64OfPAeGZe6Drn +8O4wRgYDVR0gBD8wPTA7BglghXQBWQECAQEwLjAsBggrBgEFBQcCARYgaHR0cDov +L3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBACe6 +45R88a7A3hfm5djV9VSwg/S7zV4Fe0+fdWavPOhWfvxyeDgD2StiGwC5+OlgzczO +UYrHUDFu4Up+GC9pWbY9ZIEr44OE5iKHjn3g7gKZYbge9LgriBIWhMIxkziWMaa5 +O1M/wySTVltpkuzFwbs4AOPsF6m43Md8AYOfMke6UiI0HTJ6CVanfCU2qT1L2sCC +bwq7EsiHSycR+R4tx5M/nttfJmtS2S6K8RTGRI0Vqbe/vd6mGu6uLftIdxf+u+yv +GPUqUfA5hJeVbG4bwyvEdGB5JbAKJ9/fXtI5z0V9QkvfsywexcZdylU6oJxpmo/a +77KwPJ+HbBIrZXAVUjEaJM9vMSNQH4xPjyPDdEFjHFWoFN0+4FFQz/EbMFYOkrCC +hdiDyyJkvC24JdVUorgG6q2SpCSgwYa1ShNqR88uC1aVVMvOmttqtKay20EIhid3 +92qgQmwLOM7XdVAyksLfKzAiSNDVQTglXaTpXZ/GlHXQRf0wl0OPkKsKx4ZzYEpp +Ld6leNcG2mqeSz53OiATIgHQv2ieY2BrNU0LbbqhPcCT4H8js1WtciVORvnSFu+w +ZMEBnunKoGqYDs/YYPIvSbjkQuE4NRb0yG5P94FW6LqjviOvrv1vA+ACOzB2+htt +Qc8Bsem4yWb02ybzOqR08kkkW8mw0FfB+j564ZfJ +-----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=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=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=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=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=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=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=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes +# Subject: CN=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes +# Label: "EC-ACC" +# Serial: -23701579247955709139626555126524820479 +# MD5 Fingerprint: eb:f5:9d:29:0d:61:f9:42:1f:7c:c2:ba:6d:e3:15:09 +# SHA1 Fingerprint: 28:90:3a:63:5b:52:80:fa:e6:77:4c:0b:6d:a7:d6:ba:a6:4a:f2:e8 +# SHA256 Fingerprint: 88:49:7f:01:60:2f:31:54:24:6a:e2:8c:4d:5a:ef:10:f1:d8:7e:bb:76:62:6f:4a:e0:b7:f9:5b:a7:96:87:99 +-----BEGIN CERTIFICATE----- +MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB +8zELMAkGA1UEBhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2Vy +dGlmaWNhY2lvIChOSUYgUS0wODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1 +YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYDVQQLEyxWZWdldSBodHRwczovL3d3 +dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UECxMsSmVyYXJxdWlh +IEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMTBkVD +LUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQG +EwJFUzE7MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8g +KE5JRiBRLTA4MDExNzYtSSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBD +ZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZlZ2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQu +bmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJhcnF1aWEgRW50aXRhdHMg +ZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUNDMIIBIjAN +BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R +85iKw5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm +4CgPukLjbo73FCeTae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaV +HMf5NLWUhdWZXqBIoH7nF2W4onW4HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNd +QlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0aE9jD2z3Il3rucO2n5nzbcc8t +lGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw0JDnJwIDAQAB +o4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4 +opvpXY0wfwYDVR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBo +dHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidW +ZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAwDQYJKoZIhvcN +AQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJlF7W2u++AVtd0x7Y +/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNaAl6k +SBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhy +Rp/7SNVel+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOS +Agu+TGbrIP65y7WZf+a2E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xl +nJ2lYJU6Un/10asIbvPuW/mIPX64b24D5EI= +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions RootCA 2011" +# Serial: 0 +# MD5 Fingerprint: 73:9f:4c:4b:73:5b:79:e9:fa:ba:1c:ef:6e:cb:d5:c9 +# SHA1 Fingerprint: fe:45:65:9b:79:03:5b:98:a1:61:b5:51:2e:ac:da:58:09:48:22:4d +# SHA256 Fingerprint: bc:10:4f:15:a4:8b:e7:09:dc:a5:42:a7:e1:d4:b9:df:6f:05:45:27:e8:02:ea:a9:2d:59:54:44:25:8a:fe:71 +-----BEGIN CERTIFICATE----- +MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1Ix +RDBCBgNVBAoTO0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 +dGlvbnMgQ2VydC4gQXV0aG9yaXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1p +YyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIFJvb3RDQSAyMDExMB4XDTExMTIw +NjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYTAkdSMUQwQgYDVQQK +EztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIENl +cnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEB +BQADggEPADCCAQoCggEBAKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPz +dYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJ +fel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa71HFK9+WXesyHgLacEns +bgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u8yBRQlqD +75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSP +FEDH3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNV +HRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp +5dgTBCPuQSUwRwYDVR0eBEAwPqA8MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQu +b3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQub3JnMA0GCSqGSIb3DQEBBQUA +A4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVtXdMiKahsog2p +6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 +TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7 +dIsXRSZMFpGD/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8Acys +Nnq/onN694/BtZqhFLKPM58N7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXI +l7WdmplNsDz4SgCbZN2fOUvRJ9e4 +-----END CERTIFICATE----- + +# Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967 +# Label: "Actalis Authentication Root CA" +# Serial: 6271844772424770508 +# MD5 Fingerprint: 69:c1:0d:4f:07:a3:1b:c3:fe:56:3d:04:bc:11:f6:a6 +# SHA1 Fingerprint: f3:73:b3:87:06:5a:28:84:8a:f2:f3:4a:ce:19:2b:dd:c7:8e:9c:ac +# SHA256 Fingerprint: 55:92:60:84:ec:96:3a:64:b9:6e:2a:be:01:ce:0b:a8:6a:64:fb:fe:bc:c7:aa:b5:af:c1:55:b3:7f:d7:60:66 +-----BEGIN CERTIFICATE----- +MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UE +BhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8w +MzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 +IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDkyMjExMjIwMlowazELMAkGA1UEBhMC +SVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1 +ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENB +MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNv +UTufClrJwkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX +4ay8IMKx4INRimlNAJZaby/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9 +KK3giq0itFZljoZUj5NDKd45RnijMCO6zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/ +gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1fYVEiVRvjRuPjPdA1Yprb +rxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2oxgkg4YQ +51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2F +be8lEfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxe +KF+w6D9Fz8+vm2/7hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4F +v6MGn8i1zeQf1xcGDXqVdFUNaBr8EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbn +fpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5jF66CyCU3nuDuP/jVo23Eek7 +jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLYiDrIn3hm7Ynz +ezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt +ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQAL +e3KHwGCmSUyIWOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70 +jsNjLiNmsGe+b7bAEzlgqqI0JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDz +WochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKxK3JCaKygvU5a2hi/a5iB0P2avl4V +SM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+Xlff1ANATIGk0k9j +pwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC4yyX +X04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+Ok +fcvHlXHo2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7R +K4X9p2jIugErsWx0Hbhzlefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btU +ZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXemOR/qnuOf0GZvBeyqdn6/axag67XH/JJU +LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT +LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 2 Root CA" +# Serial: 2 +# MD5 Fingerprint: 46:a7:d2:fe:45:fb:64:5a:a8:59:90:9b:78:44:9b:29 +# SHA1 Fingerprint: 49:0a:75:74:de:87:0a:47:fe:58:ee:f6:c7:6b:eb:c6:0b:12:40:99 +# SHA256 Fingerprint: 9a:11:40:25:19:7c:5b:b9:5d:94:e6:3d:55:cd:43:79:08:47:b6:46:b2:3c:df:11:ad:a4:a0:0e:ff:15:fb:48 +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMiBSb290IENBMB4XDTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1ow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1g1Lr +6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPV +L4O2fuPn9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC91 +1K2GScuVr1QGbNgGE41b/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHx +MlAQTn/0hpPshNOOvEu/XAFOBz3cFIqUCqTqc/sLUegTBxj6DvEr0VQVfTzh97QZ +QmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeffawrbD02TTqigzXsu8lkB +arcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgIzRFo1clr +Us3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLi +FRhnBkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRS +P/TizPJhk9H9Z2vXUq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN +9SG9dKpN6nIDSdvHXx1iY8f93ZHsM+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxP +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFMmAd+BikoL1Rpzz +uvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAU18h +9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s +A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3t +OluwlN5E40EIosHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo ++fsicdl9sz1Gv7SEr5AcD48Saq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7 +KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYdDnkM/crqJIByw5c/8nerQyIKx+u2 +DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWDLfJ6v9r9jv6ly0Us +H8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0oyLQ +I+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK7 +5t98biGCwWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h +3PFaTWwyI0PurKju7koSCTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPz +Y11aWOIv4x3kqdbQCtCev9eBCfHJxyYNrJgWVqA= +-----END CERTIFICATE----- + +# Issuer: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Subject: CN=Buypass Class 3 Root CA O=Buypass AS-983163327 +# Label: "Buypass Class 3 Root CA" +# Serial: 2 +# MD5 Fingerprint: 3d:3b:18:9e:2c:64:5a:e8:d5:88:ce:0e:f9:37:c2:ec +# SHA1 Fingerprint: da:fa:f7:fa:66:84:ec:06:8f:14:50:bd:c7:c2:81:a5:bc:a9:64:57 +# SHA256 Fingerprint: ed:f7:eb:bc:a2:7a:2a:38:4d:38:7b:7d:40:10:c6:66:e2:ed:b4:84:3e:4c:29:b4:ae:1d:5b:93:32:e6:b2:4d +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEd +MBsGA1UECgwUQnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3Mg +Q2xhc3MgMyBSb290IENBMB4XDTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFow +TjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBhc3MgQVMtOTgzMTYzMzI3MSAw +HgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEB +BQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRHsJ8Y +ZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3E +N3coTRiR5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9 +tznDDgFHmV0ST9tD+leh7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX +0DJq1l1sDPGzbjniazEuOQAnFN44wOwZZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c +/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH2xc519woe2v1n/MuwU8X +KhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV/afmiSTY +zIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvS +O1UQRwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D +34xFMFbG02SrZvPAXpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgP +K9Dx2hzLabjKSWJtyNBjYt1gD1iqj6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3 +AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFEe4zf/lb+74suwv +Tg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAACAj +QTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV +cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXS +IGrs/CIBKM+GuIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2 +HJLw5QY33KbmkJs4j1xrG0aGQ0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsa +O5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8ZORK15FTAaggiG6cX0S5y2CBNOxv +033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2KSb12tjE8nVhz36u +dmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz6MkE +kbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg41 +3OEMXbugUZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvD +u79leNKGef9JOxqDDPDeeOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq +4/g7u9xN12TyUb7mqqta6THuBrxzvxNiCp/HuZc= +-----END CERTIFICATE----- + +# Issuer: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Subject: CN=T-TeleSec GlobalRoot Class 3 O=T-Systems Enterprise Services GmbH OU=T-Systems Trust Center +# Label: "T-TeleSec GlobalRoot Class 3" +# Serial: 1 +# MD5 Fingerprint: ca:fb:40:a8:4e:39:92:8a:1d:fe:8e:2f:c4:27:ea:ef +# SHA1 Fingerprint: 55:a6:72:3e:cb:f2:ec:cd:c3:23:74:70:19:9d:2a:be:11:e3:81:d1 +# SHA256 Fingerprint: fd:73:da:d3:1c:64:4f:f1:b4:3b:ef:0c:cd:da:96:71:0b:9c:d9:87:5e:ca:7e:31:70:7a:f3:e9:6d:52:2b:bd +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUx +KzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAd +BgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNl +YyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgxMDAxMTAyOTU2WhcNMzMxMDAxMjM1 +OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lzdGVtcyBFbnRlcnBy +aXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBDZW50 +ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN +8ELg63iIVl6bmlQdTQyK9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/ +RLyTPWGrTs0NvvAgJ1gORH8EGoel15YUNpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4 +hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZFiP0Zf3WHHx+xGwpzJFu5 +ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W0eDrXltM +EnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1 +A/d2O2GCahKqGFPrAyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOy +WL6ukK2YJ5f+AbGwUgC4TeQbIXQbfsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ +1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzTucpH9sry9uetuUg/vBa3wW30 +6gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7hP0HHRwA11fXT +91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml +e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4p +TpPDpFQUWw== +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 2009" +# Serial: 623603 +# MD5 Fingerprint: cd:e0:25:69:8d:47:ac:9c:89:35:90:f7:fd:51:3d:2f +# SHA1 Fingerprint: 58:e8:ab:b0:36:15:33:fb:80:f7:9b:1b:6d:29:d3:ff:8d:5f:00:f0 +# SHA256 Fingerprint: 49:e7:a4:42:ac:f0:ea:62:87:05:00:54:b5:25:64:b6:50:e4:f4:9e:42:e3:48:d6:aa:38:e0:39:e9:57:b1:c1 +-----BEGIN CERTIFICATE----- +MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgMjAwOTAeFw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NTha +ME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxJzAlBgNVBAMM +HkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIwDQYJKoZIhvcNAQEB +BQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOADER03 +UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42 +tSHKXzlABF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9R +ySPocq60vFYJfxLLHLGvKZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsM +lFqVlNpQmvH/pStmMaTJOKDfHR+4CS7zp+hnUquVH+BGPtikw8paxTGA6Eian5Rp +/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUCAwEAAaOCARowggEWMA8G +A1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ4PGEMA4G +A1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVj +dG9yeS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUy +MENBJTIwMiUyMDIwMDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRl +cmV2b2NhdGlvbmxpc3QwQ6BBoD+GPWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3Js +L2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAwOS5jcmwwDQYJKoZIhvcNAQEL +BQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm2H6NMLVwMeni +acfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 +o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4K +zCUqNQT4YJEVdT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8 +PIWmawomDeCTmGCufsYkl4phX5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3Y +Johw1+qRzT65ysCQblrGXnRl11z+o+I= +-----END CERTIFICATE----- + +# Issuer: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Subject: CN=D-TRUST Root Class 3 CA 2 EV 2009 O=D-Trust GmbH +# Label: "D-TRUST Root Class 3 CA 2 EV 2009" +# Serial: 623604 +# MD5 Fingerprint: aa:c6:43:2c:5e:2d:cd:c4:34:c0:50:4f:11:02:4f:b6 +# SHA1 Fingerprint: 96:c9:1b:0b:95:b4:10:98:42:fa:d0:d8:22:79:fe:60:fa:b9:16:83 +# SHA256 Fingerprint: ee:c5:49:6b:98:8c:e9:86:25:b9:34:09:2e:ec:29:08:be:d0:b0:f3:16:c2:d4:73:0c:84:ea:f1:f3:d3:48:81 +-----BEGIN CERTIFICATE----- +MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRF +MRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBD +bGFzcyAzIENBIDIgRVYgMjAwOTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUw +NDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxELVRydXN0IEdtYkgxKjAoBgNV +BAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAwOTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfSegpn +ljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM0 +3TP1YtHhzRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6Z +qQTMFexgaDbtCHu39b+T7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lR +p75mpoo6Kr3HGrHhFPC+Oh25z1uxav60sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8 +HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure3511H3a6UCAwEAAaOCASQw +ggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyvcop9Ntea +HNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFw +Oi8vZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xh +c3MlMjAzJTIwQ0ElMjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1E +RT9jZXJ0aWZpY2F0ZXJldm9jYXRpb25saXN0MEagRKBChkBodHRwOi8vd3d3LmQt +dHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xhc3NfM19jYV8yX2V2XzIwMDku +Y3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+PPoeUSbrh/Yp +3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 +nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNF +CSuGdXzfX2lXANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7na +xpeG0ILD5EJt/rDiZE4OJudANCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqX +KVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVvw9y4AyHqnxbxLFS1 +-----END CERTIFICATE----- + +# Issuer: CN=CA Disig Root R2 O=Disig a.s. +# Subject: CN=CA Disig Root R2 O=Disig a.s. +# Label: "CA Disig Root R2" +# Serial: 10572350602393338211 +# MD5 Fingerprint: 26:01:fb:d8:27:a7:17:9a:45:54:38:1a:43:01:3b:03 +# SHA1 Fingerprint: b5:61:eb:ea:a4:de:e4:25:4b:69:1a:98:a5:57:47:c2:34:c7:d9:71 +# SHA256 Fingerprint: e2:3d:4a:03:6d:7b:70:e9:f5:95:b1:42:20:79:d2:b9:1e:df:bb:1f:b6:51:a0:63:3e:aa:8a:9d:c5:f8:07:03 +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNV +BAYTAlNLMRMwEQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMu +MRkwFwYDVQQDExBDQSBEaXNpZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQy +MDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sxEzARBgNVBAcTCkJyYXRpc2xhdmEx +EzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERpc2lnIFJvb3QgUjIw +ggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbCw3Oe +NcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNH +PWSb6WiaxswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3I +x2ymrdMxp7zo5eFm1tL7A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbe +QTg06ov80egEFGEtQX6sx3dOy1FU+16SGBsEWmjGycT6txOgmLcRK7fWV8x8nhfR +yyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqVg8NTEQxzHQuyRpDRQjrO +QG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa5Beny912 +H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJ +QfYEkoopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUD +i/ZnWejBBhG93c+AAk9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORs +nLMOPReisjQS1n6yqEm70XooQL6iFh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1 +rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud +DwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5uQu0wDQYJKoZI +hvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM +tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqf +GopTpti72TVVsRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkb +lvdhuDvEK7Z4bLQjb/D907JedR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka ++elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W81k/BfDxujRNt+3vrMNDcTa/F1bal +TFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjxmHHEt38OFdAlab0i +nSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01utI3 +gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18Dr +G5gPcFw0sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3Os +zMOl6W8KjptlwlCFtaOgUxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8x +L4ysEr3vQCj8KWefshNPZiTEUxnpHikV7+ZtsH8tZ/3zbBt1RqPlShfppNcL +-----END CERTIFICATE----- + +# Issuer: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Subject: CN=ACCVRAIZ1 O=ACCV OU=PKIACCV +# Label: "ACCVRAIZ1" +# Serial: 6828503384748696800 +# MD5 Fingerprint: d0:a0:5a:ee:05:b6:09:94:21:a1:7d:f1:b2:29:82:02 +# SHA1 Fingerprint: 93:05:7a:88:15:c6:4f:ce:88:2f:fa:91:16:52:28:78:bc:53:64:17 +# SHA256 Fingerprint: 9a:6e:c0:12:e1:a7:da:9d:be:34:19:4d:47:8a:d7:c0:db:18:22:fb:07:1d:f1:29:81:49:6e:d1:04:38:41:13 +-----BEGIN CERTIFICATE----- +MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UE +AwwJQUNDVlJBSVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQsw +CQYDVQQGEwJFUzAeFw0xMTA1MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQ +BgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwHUEtJQUNDVjENMAsGA1UECgwEQUND +VjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCb +qau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gMjmoY +HtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWo +G2ioPej0RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpA +lHPrzg5XPAOBOp0KoVdDaaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhr +IA8wKFSVf+DuzgpmndFALW4ir50awQUZ0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/ +0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDGWuzndN9wrqODJerWx5eH +k6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs78yM2x/47 +4KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMO +m3WR5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpa +cXpkatcnYGMN285J9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPl +uUsXQA+xtrn13k/c4LOsOxFwYIRKQ26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYI +KwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRwOi8vd3d3LmFjY3YuZXMvZmls +ZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEuY3J0MB8GCCsG +AQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 +VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeT +VfZW6oHlNsyMHj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIG +CCsGAQUFBwICMIIBFB6CARAAQQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUA +cgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBhAO0AegAgAGQAZQAgAGwAYQAgAEEA +QwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUAYwBuAG8AbABvAGcA +7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBjAHQA +cgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAA +QwBQAFMAIABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUA +czAwBggrBgEFBQcCARYkaHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2Mu +aHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRt +aW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2MV9kZXIuY3JsMA4GA1Ud +DwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZIhvcNAQEF +BQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdp +D70ER9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gU +JyCpZET/LtZ1qmxNYEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+m +AM/EKXMRNt6GGT6d7hmKG9Ww7Y49nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepD +vV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJTS+xJlsndQAJxGJ3KQhfnlms +tn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3sCPdK6jT2iWH +7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h +I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szA +h1xA2syVP1XgNce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xF +d3+YJ5oyXSrjhO7FmGYvliAd3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2H +pPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3pEfbRD0tVNEYqi4Y7 +-----END CERTIFICATE----- + +# Issuer: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Subject: CN=TWCA Global Root CA O=TAIWAN-CA OU=Root CA +# Label: "TWCA Global Root CA" +# Serial: 3262 +# MD5 Fingerprint: f9:03:7e:cf:e6:9e:3c:73:7a:2a:90:07:69:ff:2b:96 +# SHA1 Fingerprint: 9c:bb:48:53:f6:a4:f6:d3:52:a4:e8:32:52:55:60:13:f5:ad:af:65 +# SHA256 Fingerprint: 59:76:90:07:f7:68:5d:0f:cd:50:87:2f:9f:95:d5:75:5a:5b:2b:45:7d:81:f3:69:2b:61:0a:98:67:2f:0e:1b +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcx +EjAQBgNVBAoTCVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMT +VFdDQSBHbG9iYWwgUm9vdCBDQTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5 +NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQKEwlUQUlXQU4tQ0ExEDAOBgNVBAsT +B1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3QgQ0EwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2CnJfF +10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz +0ALfUPZVr2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfCh +MBwqoJimFb3u/Rk28OKRQ4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbH +zIh1HrtsBv+baz4X7GGqcXzGHaL3SekVtTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc +46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1WKKD+u4ZqyPpcC1jcxkt2 +yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99sy2sbZCi +laLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYP +oA/pyJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQA +BDzfuBSO6N+pjWxnkjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcE +qYSjMq+u7msXi7Kx/mzhkIyIqJdIzshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm +4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB +/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6gcFGn90xHNcgL +1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn +LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WF +H6vPNOw/KP4M8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNo +RI2T9GRwoD2dKAXDOXC4Ynsg/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+ +nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlglPx4mI88k1HtQJAH32RjJMtOcQWh +15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryPA9gK8kxkRr05YuWW +6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3mi4TW +nsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5j +wa19hAM8EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWz +aGHQRiapIVJpLesux+t3zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmy +KwbQBM0= +-----END CERTIFICATE----- + +# Issuer: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Subject: CN=TeliaSonera Root CA v1 O=TeliaSonera +# Label: "TeliaSonera Root CA v1" +# Serial: 199041966741090107964904287217786801558 +# MD5 Fingerprint: 37:41:49:1b:18:56:9a:26:f5:ad:c2:66:fb:40:a5:4c +# SHA1 Fingerprint: 43:13:bb:96:f1:d5:86:9b:c1:4e:6a:92:f6:cf:f6:34:69:87:82:37 +# SHA256 Fingerprint: dd:69:36:fe:21:f8:f0:77:c1:23:a1:a5:21:c1:22:24:f7:22:55:b7:3e:03:a7:26:06:93:e8:a2:4b:0f:a3:89 +-----BEGIN CERTIFICATE----- +MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAw +NzEUMBIGA1UECgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJv +b3QgQ0EgdjEwHhcNMDcxMDE4MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYD +VQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwWVGVsaWFTb25lcmEgUm9vdCBDQSB2 +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+6yfwIaPzaSZVfp3F +VRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA3GV1 +7CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+X +Z75Ljo1kB1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+ +/jXh7VB7qTCNGdMJjmhnXb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs +81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxHoLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkm +dtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3F0fUTPHSiXk+TT2YqGHe +Oh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJoWjiUIMu +sDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4 +pgd7gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fs +slESl1MpWtTwEhDcTwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQ +arMCpgKIv7NHfirZ1fpoeDVNAgMBAAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYD +VR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qWDNXr+nuqF+gTEjANBgkqhkiG +9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNmzqjMDfz1mgbl +dxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx +0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1Tj +TQpgcmLNkQfWpb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBed +Y2gea+zDTYa4EzAvXUYNR0PVG6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7 +Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpcc41teyWRyu5FrgZLAMzTsVlQ2jqI +OylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOTJsjrDNYmiLbAJM+7 +vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2qReW +t88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcn +HL/EVlP6Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVx +SK236thZiNSQvxaz2emsWWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= +-----END CERTIFICATE----- + +# Issuer: CN=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 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=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Subject: CN=OISTE WISeKey Global Root GB CA O=WISeKey OU=OISTE Foundation Endorsed +# Label: "OISTE WISeKey Global Root GB CA" +# Serial: 157768595616588414422159278966750757568 +# MD5 Fingerprint: a4:eb:b9:61:28:2e:b7:2f:98:b0:35:26:90:99:51:1d +# SHA1 Fingerprint: 0f:f9:40:76:18:d3:d7:6a:4b:98:f0:a8:35:9e:0c:fd:27:ac:cc:ed +# SHA256 Fingerprint: 6b:9c:08:e8:6e:b0:f7:67:cf:ad:65:cd:98:b6:21:49:e5:49:4a:67:f5:84:5e:7b:d1:ed:01:9f:27:b8:6b:d6 +-----BEGIN CERTIFICATE----- +MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBt +MQswCQYDVQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUg +Rm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9i +YWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAwMzJaFw0zOTEyMDExNTEwMzFaMG0x +CzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQLExlPSVNURSBG +b3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh +bCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3 +HEokKtaXscriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGx +WuR51jIjK+FTzJlFXHtPrby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX +1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNk +u7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4oQnc/nSMbsrY9gBQHTC5P +99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvgGUpuuy9r +M2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUB +BAMCAQAwDQYJKoZIhvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrgh +cViXfa43FK8+5/ea4n32cZiZBKpDdHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5 +gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0VQreUGdNZtGn//3ZwLWoo4rO +ZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEuiHZeeevJuQHHf +aPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic +Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM= +-----END CERTIFICATE----- + +# Issuer: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Subject: CN=SZAFIR ROOT CA2 O=Krajowa Izba Rozliczeniowa S.A. +# Label: "SZAFIR ROOT CA2" +# Serial: 357043034767186914217277344587386743377558296292 +# MD5 Fingerprint: 11:64:c1:89:b0:24:b1:8c:b1:07:7e:89:9e:51:9e:99 +# SHA1 Fingerprint: e2:52:fa:95:3f:ed:db:24:60:bd:6e:28:f3:9c:cc:cf:5e:b3:3f:de +# SHA256 Fingerprint: a1:33:9d:33:28:1a:0b:56:e5:57:d3:d3:2b:1c:e7:f9:36:7e:b0:94:bd:5f:a7:2a:7e:50:04:c8:de:d7:ca:fe +-----BEGIN CERTIFICATE----- +MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQEL +BQAwUTELMAkGA1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6 +ZW5pb3dhIFMuQS4xGDAWBgNVBAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkw +NzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJBgNVBAYTAlBMMSgwJgYDVQQKDB9L +cmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYDVQQDDA9TWkFGSVIg +Uk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5QqEvN +QLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT +3PSQ1hNKDJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw +3gAeqDRHu5rr/gsUvTaE2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr6 +3fE9biCloBK0TXC5ztdyO4mTp4CEHCdJckm1/zuVnsHMyAHs6A6KCpbns6aH5db5 +BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwiieDhZNRnvDF5YTy7ykHN +XGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD +AgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsF +AAOCAQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw +8PRBEew/R40/cof5O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOG +nXkZ7/e7DDWQw4rtTw/1zBLZpD67oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCP +oky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul4+vJhaAlIDf7js4MNIThPIGy +d05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6+/NNIxuZMzSg +LvWpCz/UXeHPhJ/iGcJfitYgHuNztw== +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Network CA 2 O=Unizeto Technologies S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Network CA 2" +# Serial: 44979900017204383099463764357512596969 +# MD5 Fingerprint: 6d:46:9e:d9:25:6d:08:23:5b:5e:74:7d:1e:27:db:f2 +# SHA1 Fingerprint: d3:dd:48:3e:2b:bf:4c:05:e8:af:10:f5:fa:76:26:cf:d3:dc:30:92 +# SHA256 Fingerprint: b6:76:f2:ed:da:e8:77:5c:d3:6c:b0:f6:3c:d1:d4:60:39:61:f4:9e:62:65:ba:01:3a:2f:03:07:b6:d0:b8:04 +-----BEGIN CERTIFICATE----- +MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCB +gDELMAkGA1UEBhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMu +QS4xJzAlBgNVBAsTHkNlcnR1bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIG +A1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29yayBDQSAyMCIYDzIwMTExMDA2MDgz +OTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQTDEiMCAGA1UEChMZ +VW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3 +b3JrIENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWA +DGSdhhuWZGc/IjoedQF97/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn +0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+oCgCXhVqqndwpyeI1B+twTUrWwbNWuKFB +OJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40bRr5HMNUuctHFY9rnY3lE +fktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2puTRZCr+E +Sv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1m +o130GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02i +sx7QBlrd9pPPV3WZ9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOW +OZV7bIBaTxNyxtd9KXpEulKkKtVBRgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgez +Tv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pyehizKV/Ma5ciSixqClnrDvFAS +adgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vMBhBgu4M1t15n +3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQ +F/xlhMcQSZDe28cmk4gmb3DWAl45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTf +CVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuAL55MYIR4PSFk1vtBHxgP58l1cb29 +XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMoclm2q8KMZiYcdywm +djWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tMpkT/ +WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jb +AoJnwTnbw3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksq +P/ujmv5zMnHCnsZy4YpoJ/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Ko +b7a6bINDd82Kkhehnlt4Fj1F4jNy3eFmypnTycUm/Q1oBEauttmbjL4ZvrHG8hnj +XALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLXis7VmFxWlgPF7ncGNf/P +5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7zAYspsbi +DrW5viSP +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: ca:ff:e2:db:03:d9:cb:4b:e9:0f:ad:84:fd:7b:18:ce +# SHA1 Fingerprint: 01:0c:06:95:a6:98:19:14:ff:bf:5f:c6:b0:b6:95:ea:29:e9:12:a6 +# SHA256 Fingerprint: a0:40:92:9a:02:ce:53:b4:ac:f4:f2:ff:c6:98:1c:e4:49:6f:75:5e:6d:45:fe:0b:2a:69:2b:cd:52:52:3f:36 +-----BEGIN CERTIFICATE----- +MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1Ix +DzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5k +IFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMT +N0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9v +dENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAxMTIxWjCBpjELMAkG +A1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNh +ZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkx +QDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1 +dGlvbnMgUm9vdENBIDIwMTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQDC+Kk/G4n8PDwEXT2QNrCROnk8ZlrvbTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA +4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+ehiGsxr/CL0BgzuNtFajT0 +AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+6PAQZe10 +4S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06C +ojXdFPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV +9Cz82XBST3i4vTwri5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrD +gfgXy5I2XdGj2HUb4Ysn6npIQf1FGQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6 +Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2fu/Z8VFRfS0myGlZYeCsargq +NhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9muiNX6hME6wGko +LfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc +Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVd +ctA4GGqd83EkVAswDQYJKoZIhvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0I +XtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+D1hYc2Ryx+hFjtyp8iY/xnmMsVMI +M4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrMd/K4kPFox/la/vot +9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+yd+2V +Z5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/ea +j8GsGsVn82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnh +X9izjFk0WaSrT2y7HxjbdavYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQ +l033DlZdwJVqwjbDG2jJ9SrcR5q+ss7FJej6A7na+RZukYT1HCjI/CbM1xyQVqdf +bzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVtJ94Cj8rDtSvK6evIIVM4 +pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGaJI7ZjnHK +e7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0 +vm9qp/UsQu0yrbYhnr68 +-----END CERTIFICATE----- + +# Issuer: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Subject: CN=Hellenic Academic and Research Institutions ECC RootCA 2015 O=Hellenic Academic and Research Institutions Cert. Authority +# Label: "Hellenic Academic and Research Institutions ECC RootCA 2015" +# Serial: 0 +# MD5 Fingerprint: 81:e5:b4:17:eb:c2:f5:e1:4b:0d:41:7b:49:92:fe:ef +# SHA1 Fingerprint: 9f:f1:71:8d:92:d5:9a:f3:7d:74:97:b4:bc:6f:84:68:0b:ba:b6:66 +# SHA256 Fingerprint: 44:b5:45:aa:8a:25:e6:5a:73:ca:15:dc:27:fc:36:d2:4c:1c:b9:95:3a:06:65:39:b1:15:82:dc:48:7b:48:33 +-----BEGIN CERTIFICATE----- +MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzAN +BgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hl +bGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgRUNDIFJv +b3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEwMzcxMlowgaoxCzAJ +BgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmljIEFj +YWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5 +MUQwQgYDVQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0 +dXRpb25zIEVDQyBSb290Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKg +QehLgoRc4vgxEZmGZE4JJS+dQS8KrjVPdJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJa +jq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoKVlp8aQuqgAkkbH7BRqNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFLQi +C4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaep +lSTAGiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7Sof +TUwJCA3sS61kFyjndc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR +-----END CERTIFICATE----- + +# Issuer: CN=ISRG Root X1 O=Internet Security Research Group +# Subject: CN=ISRG Root X1 O=Internet Security Research Group +# Label: "ISRG Root X1" +# Serial: 172886928669790476064670243504169061120 +# MD5 Fingerprint: 0c:d2:f9:e0:da:17:73:e9:ed:86:4d:a5:e3:70:e7:4e +# SHA1 Fingerprint: ca:bd:2a:79:a1:07:6a:31:f2:1d:25:36:35:cb:03:9d:43:29:a5:e8 +# SHA256 Fingerprint: 96:bc:ec:06:26:49:76:f3:74:60:77:9a:cf:28:c5:a7:cf:e8:a3:c0:aa:e1:1a:8f:fc:ee:05:c0:bd:df:08:c6 +-----BEGIN CERTIFICATE----- +MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAw +TzELMAkGA1UEBhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2Vh +cmNoIEdyb3VwMRUwEwYDVQQDEwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4 +WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJu +ZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBY +MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54rVygc +h77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+ +0TM8ukj13Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6U +A5/TR5d8mUgjU+g4rk8Kb4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sW +T8KOEUt+zwvo/7V3LvSye0rgTBIlDHCNAymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyH +B5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ4Q7e2RCOFvu396j3x+UC +B5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf1b0SHzUv +KBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWn +OlFuhjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTn +jh8BCNAw1FtxNrQHusEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbw +qHyGO0aoSCqI3Haadr8faqU9GY/rOPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CI +rU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY9umbbjANBgkq +hkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL +ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ +3BebYhtF8GaV0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KK +NFtY2PwByVS5uCbMiogziUwthDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5 +ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJwTdwJx4nLCgdNbOhdjsnvzqvHu7Ur +TkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nxe5AW0wdeRlN8NwdC +jNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZAJzVc +oyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq +4RgqsahDYVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPA +mRGunUHBcnWEvgJBQl9nJEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57d +emyPxgcYxn/eR44/KJ4EBs+lVDR3veyJm+kXQ99b21/+jh5Xos1AnX5iItreGCc= +-----END CERTIFICATE----- + +# Issuer: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Subject: O=FNMT-RCM OU=AC RAIZ FNMT-RCM +# Label: "AC RAIZ FNMT-RCM" +# Serial: 485876308206448804701554682760554759 +# MD5 Fingerprint: e2:09:04:b4:d3:bd:d1:a0:14:fd:1a:d2:47:c4:57:1d +# SHA1 Fingerprint: ec:50:35:07:b2:15:c4:95:62:19:e2:a8:9a:5b:42:99:2c:4c:2c:20 +# SHA256 Fingerprint: eb:c5:57:0c:29:01:8c:4d:67:b1:aa:12:7b:af:12:f7:03:b4:61:1e:bc:17:b7:da:b5:57:38:94:17:9b:93:fa +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsx +CzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJ +WiBGTk1ULVJDTTAeFw0wODEwMjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJ +BgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBG +Tk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBALpxgHpMhm5/ +yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcfqQgf +BBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAz +WHFctPVrbtQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxF +tBDXaEAUwED653cXeuYLj2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z +374jNUUeAlz+taibmSXaXvMiwzn15Cou08YfxGyqxRxqAQVKL9LFwag0Jl1mpdIC +IfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mwWsXmo8RZZUc1g16p6DUL +mbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnTtOmlcYF7 +wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peS +MKGJ47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2 +ZSysV4999AeU14ECll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMet +UqIJ5G+GR4of6ygnXYMgrwTJbFaai0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFPd9xf3E6Jobd2Sn9R2gzL+H +YJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1odHRwOi8vd3d3 +LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD +nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1 +RXxlDPiyN8+sD8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYM +LVN0V2Ue1bLdI4E7pWYjJ2cJj+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf +77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrTQfv6MooqtyuGC2mDOL7Nii4LcK2N +JpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW+YJF1DngoABd15jm +fZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7Ixjp +6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp +1txyM/1d8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B +9kiABdcPUXmsEKvU7ANm5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wok +RqEIr9baRRmW1FMdW4R58MD3R++Lj8UGrp1MYp3/RgT408m2ECVAdf4WqslKYIYv +uu8wd+RU4riEmViAqhOLUTpPSPaLtrM= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 1 O=Amazon +# Subject: CN=Amazon Root CA 1 O=Amazon +# Label: "Amazon Root CA 1" +# Serial: 143266978916655856878034712317230054538369994 +# MD5 Fingerprint: 43:c6:bf:ae:ec:fe:ad:2f:18:c6:88:68:30:fc:c8:e6 +# SHA1 Fingerprint: 8d:a7:f9:65:ec:5e:fc:37:91:0f:1c:6e:59:fd:c1:cc:6a:6e:de:16 +# SHA256 Fingerprint: 8e:cd:e6:88:4f:3d:87:b1:12:5b:a3:1a:c3:fc:b1:3d:70:16:de:7f:57:cc:90:4f:e1:cb:97:c6:ae:98:19:6e +-----BEGIN CERTIFICATE----- +MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAxMB4XDTE1MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALJ4gHHKeNXj +ca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgHFzZM +9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qw +IFAGbHrQgLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6 +VOujw5H5SNz/0egwLX0tdHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L +93FcXmn/6pUCyziKrlA4b9v7LWIbxcceVOF34GfID5yHI9Y/QCB/IIDEgEw+OyQm +jgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3DQEBCwUA +A4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDI +U5PMCCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUs +N+gDS63pYaACbvXy8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vv +o/ufQJVtMVT8QtPHRh8jrdkPSHCa2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU +5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2xJNDd2ZhwLnoQdeXeGADbkpy +rqXRfboQnoZsG4q5WTP468SQvvG5 +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 2 O=Amazon +# Subject: CN=Amazon Root CA 2 O=Amazon +# Label: "Amazon Root CA 2" +# Serial: 143266982885963551818349160658925006970653239 +# MD5 Fingerprint: c8:e5:8d:ce:a8:42:e2:7a:c0:2a:5c:7c:9e:26:bf:66 +# SHA1 Fingerprint: 5a:8c:ef:45:d7:a6:98:59:76:7a:8c:8b:44:96:b5:78:cf:47:4b:1a +# SHA256 Fingerprint: 1b:a5:b2:aa:8c:65:40:1a:82:96:01:18:f8:0b:ec:4f:62:30:4d:83:ce:c4:71:3a:19:c3:9c:01:1e:a4:6d:b4 +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwF +ADA5MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6 +b24gUm9vdCBDQSAyMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTEL +MAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJv +b3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK2Wny2cSkxK +gXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4kHbZ +W0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg +1dKmSYXpN+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K +8nu+NQWpEjTj82R0Yiw9AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r +2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvdfLC6HM783k81ds8P+HgfajZRRidhW+me +z/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAExkv8LV/SasrlX6avvDXbR +8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSSbtqDT6Zj +mUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz +7Mt0Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6 ++XUyo05f7O0oYtlNc/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI +0u1ufm8/0i2BWSlmy5A5lREedCf+3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMB +Af8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSwDPBMMPQFWAJI/TPlUq9LhONm +UjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oAA7CXDpO8Wqj2 +LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY ++gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kS +k5Nrp+gvU5LEYFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl +7uxMMne0nxrpS10gxdr9HIcWxkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygm +btmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQgj9sAq+uEjonljYE1x2igGOpm/Hl +urR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbWaQbLU8uz/mtBzUF+ +fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoVYh63 +n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE +76KlXIx3KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H +9jVlpNMKVv/1F2Rs76giJUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT +4PsJYGw= +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 3 O=Amazon +# Subject: CN=Amazon Root CA 3 O=Amazon +# Label: "Amazon Root CA 3" +# Serial: 143266986699090766294700635381230934788665930 +# MD5 Fingerprint: a0:d4:ef:0b:f7:b5:d8:49:95:2a:ec:f5:c4:fc:81:87 +# SHA1 Fingerprint: 0d:44:dd:8c:3c:8c:1a:1a:58:75:64:81:e9:0f:2e:2a:ff:b3:d2:6e +# SHA256 Fingerprint: 18:ce:6c:fe:7b:f1:4e:60:b2:e3:47:b8:df:e8:68:cb:31:d0:2e:bb:3a:da:27:15:69:f5:03:43:b4:6d:b3:a4 +-----BEGIN CERTIFICATE----- +MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSAzMB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZBf8ANm+gBG1bG8lKl +ui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjrZt6j +QjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSr +ttvXBp43rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkr +BqWTrBqYaGFy+uGh0PsceGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteM +YyRIHN8wfdVoOw== +-----END CERTIFICATE----- + +# Issuer: CN=Amazon Root CA 4 O=Amazon +# Subject: CN=Amazon Root CA 4 O=Amazon +# Label: "Amazon Root CA 4" +# Serial: 143266989758080763974105200630763877849284878 +# MD5 Fingerprint: 89:bc:27:d5:eb:17:8d:06:6a:69:d5:fd:89:47:b4:cd +# SHA1 Fingerprint: f6:10:84:07:d6:f8:bb:67:98:0c:c2:e2:44:c2:eb:ae:1c:ef:63:be +# SHA256 Fingerprint: e3:5d:28:41:9e:d0:20:25:cf:a6:90:38:cd:62:39:62:45:8d:a5:c6:95:fb:de:a3:c2:2b:0b:fb:25:89:70:92 +-----BEGIN CERTIFICATE----- +MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5 +MQswCQYDVQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24g +Um9vdCBDQSA0MB4XDTE1MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkG +A1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZMBcGA1UEAxMQQW1hem9uIFJvb3Qg +Q0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN/sGKe0uoe0ZLY7Bi +9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri83Bk +M6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WB +MAoGCCqGSM49BAMDA2gAMGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlw +CkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1AE47xDqUEpHJWEadIRNyp4iciuRMStuW +1KyLa2tJElMzrdfkviT8tQp21KW8EA== +-----END CERTIFICATE----- + +# Issuer: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Subject: CN=TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 O=Turkiye Bilimsel ve Teknolojik Arastirma Kurumu - TUBITAK OU=Kamu Sertifikasyon Merkezi - Kamu SM +# Label: "TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1" +# Serial: 1 +# MD5 Fingerprint: dc:00:81:dc:69:2f:3e:2f:b0:3b:f6:3d:5a:91:8e:49 +# SHA1 Fingerprint: 31:43:64:9b:ec:ce:27:ec:ed:3a:3f:0b:8f:0d:e4:e8:91:dd:ee:ca +# SHA256 Fingerprint: 46:ed:c3:68:90:46:d5:3a:45:3f:b3:10:4a:b8:0d:ca:ec:65:8b:26:60:ea:16:29:dd:7e:86:79:90:64:87:16 +-----BEGIN CERTIFICATE----- +MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIx +GDAWBgNVBAcTD0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxp +bXNlbCB2ZSBUZWtub2xvamlrIEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0w +KwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24gTWVya2V6aSAtIEthbXUgU00xNjA0 +BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRpZmlrYXNpIC0gU3Vy +dW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYDVQQG +EwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXll +IEJpbGltc2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklU +QUsxLTArBgNVBAsTJEthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBT +TTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11IFNNIFNTTCBLb2sgU2VydGlmaWthc2kg +LSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAr3UwM6q7 +a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y86Ij5iySr +LqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INr +N3wcwv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2X +YacQuFWQfw4tJzh03+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/ +iSIzL+aFCr2lqBs23tPcLG07xxO9WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4f +AJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQUZT/HiobGPN08VFw1+DrtUgxH +V8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEL +BQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh +AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPf +IPP54+M638yclNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4 +lzwDGrpDxpa5RXI4s6ehlj2Re37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c +8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0jq5Rm+K37DwhuJi1/FwcJsoz7UMCf +lo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM= +-----END CERTIFICATE----- + +# Issuer: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Subject: CN=GDCA TrustAUTH R5 ROOT O=GUANG DONG CERTIFICATE AUTHORITY CO.,LTD. +# Label: "GDCA TrustAUTH R5 ROOT" +# Serial: 9009899650740120186 +# MD5 Fingerprint: 63:cc:d9:3d:34:35:5c:6f:53:a3:e2:08:70:48:1f:b4 +# SHA1 Fingerprint: 0f:36:38:5b:81:1a:25:c3:9b:31:4e:83:ca:e9:34:66:70:cc:74:b4 +# SHA256 Fingerprint: bf:ff:8f:d0:44:33:48:7d:6a:8a:a6:0c:1a:29:76:7a:9f:c2:bb:b0:5e:42:0f:71:3a:13:b9:92:89:1d:38:93 +-----BEGIN CERTIFICATE----- +MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UE +BhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ +IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0 +MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVowYjELMAkGA1UEBhMCQ04xMjAwBgNV +BAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8w +HQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJj +Dp6L3TQsAlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBj +TnnEt1u9ol2x8kECK62pOqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+u +KU49tm7srsHwJ5uu4/Ts765/94Y9cnrrpftZTqfrlYwiOXnhLQiPzLyRuEH3FMEj +qcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ9Cy5WmYqsBebnh52nUpm +MUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQxXABZG12 +ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloP +zgsMR6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3Gk +L30SgLdTMEZeS1SZD2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeC +jGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4oR24qoAATILnsn8JuLwwoC8N9VKejveSswoA +HQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx9hoh49pwBiFYFIeFd3mqgnkC +AwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlRMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg +p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZm +DRd9FBUb1Ov9H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5 +COmSdI31R9KrO9b7eGZONn356ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ry +L3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd+PwyvzeG5LuOmCd+uh8W4XAR8gPf +JWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQHtZa37dG/OaG+svg +IHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBDF8Io +2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV +09tL7ECQ8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQ +XR4EzzffHqhmsYzmIGrv/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrq +T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe +MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== +-----END CERTIFICATE----- + +# Issuer: CN=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----- + +# Issuer: CN=Entrust Root Certification Authority - G4 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2015 Entrust, Inc. - for authorized use only +# Subject: CN=Entrust Root Certification Authority - G4 O=Entrust, Inc. OU=See www.entrust.net/legal-terms/(c) 2015 Entrust, Inc. - for authorized use only +# Label: "Entrust Root Certification Authority - G4" +# Serial: 289383649854506086828220374796556676440 +# MD5 Fingerprint: 89:53:f1:83:23:b7:7c:8e:05:f1:8c:71:38:4e:1f:88 +# SHA1 Fingerprint: 14:88:4e:86:26:37:b0:26:af:59:62:5c:40:77:ec:35:29:ba:96:01 +# SHA256 Fingerprint: db:35:17:d1:f6:73:2a:2d:5a:b9:7c:53:3e:c7:07:79:ee:32:70:a6:2f:b4:ac:42:38:37:24:60:e6:f0:1e:88 +-----BEGIN CERTIFICATE----- +MIIGSzCCBDOgAwIBAgIRANm1Q3+vqTkPAAAAAFVlrVgwDQYJKoZIhvcNAQELBQAw +gb4xCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQL +Ex9TZWUgd3d3LmVudHJ1c3QubmV0L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykg +MjAxNSBFbnRydXN0LCBJbmMuIC0gZm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMjAw +BgNVBAMTKUVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEc0 +MB4XDTE1MDUyNzExMTExNloXDTM3MTIyNzExNDExNlowgb4xCzAJBgNVBAYTAlVT +MRYwFAYDVQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1 +c3QubmV0L2xlZ2FsLXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxNSBFbnRydXN0LCBJ +bmMuIC0gZm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxMjAwBgNVBAMTKUVudHJ1c3Qg +Um9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEc0MIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEAsewsQu7i0TD/pZJH4i3DumSXbcr3DbVZwbPLqGgZ +2K+EbTBwXX7zLtJTmeH+H17ZSK9dE43b/2MzTdMAArzE+NEGCJR5WIoV3imz/f3E +T+iq4qA7ec2/a0My3dl0ELn39GjUu9CH1apLiipvKgS1sqbHoHrmSKvS0VnM1n4j +5pds8ELl3FFLFUHtSUrJ3hCX1nbB76W1NhSXNdh4IjVS70O92yfbYVaCNNzLiGAM +C1rlLAHGVK/XqsEQe9IFWrhAnoanw5CGAlZSCXqc0ieCU0plUmr1POeo8pyvi73T +DtTUXm6Hnmo9RR3RXRv06QqsYJn7ibT/mCzPfB3pAqoEmh643IhuJbNsZvc8kPNX +wbMv9W3y+8qh+CmdRouzavbmZwe+LGcKKh9asj5XxNMhIWNlUpEbsZmOeX7m640A +2Vqq6nPopIICR5b+W45UYaPrL0swsIsjdXJ8ITzI9vF01Bx7owVV7rtNOzK+mndm +nqxpkCIHH2E6lr7lmk/MBTwoWdPBDFSoWWG9yHJM6Nyfh3+9nEg2XpWjDrk4JFX8 +dWbrAuMINClKxuMrLzOg2qOGpRKX/YAr2hRC45K9PvJdXmd0LhyIRyk0X+IyqJwl +N4y6mACXi0mWHv0liqzc2thddG5msP9E36EYxr5ILzeUePiVSj9/E15dWf10hkNj +c0kCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFJ84xFYjwznooHFs6FRM5Og6sb9nMA0GCSqGSIb3DQEBCwUAA4ICAQAS +5UKme4sPDORGpbZgQIeMJX6tuGguW8ZAdjwD+MlZ9POrYs4QjbRaZIxowLByQzTS +Gwv2LFPSypBLhmb8qoMi9IsabyZIrHZ3CL/FmFz0Jomee8O5ZDIBf9PD3Vht7LGr +hFV0d4QEJ1JrhkzO3bll/9bGXp+aEJlLdWr+aumXIOTkdnrG0CSqkM0gkLpHZPt/ +B7NTeLUKYvJzQ85BK4FqLoUWlFPUa19yIqtRLULVAJyZv967lDtX/Zr1hstWO1uI +AeV8KEsD+UmDfLJ/fOPtjqF/YFOOVZ1QNBIPt5d7bIdKROf1beyAN/BYGW5KaHbw +H5Lk6rWS02FREAutp9lfx1/cH6NcjKF+m7ee01ZvZl4HliDtC3T7Zk6LERXpgUl+ +b7DUUH8i119lAg2m9IUe2K4GS0qn0jFmwvjO5QimpAKWRGhXxNUzzxkvFMSUHHuk +2fCfDrGA4tGeEWSpiBE6doLlYsKA2KSD7ZPvfC+QsDJMlhVoSFLUmQjAJOgc47Ol +IQ6SwJAfzyBfyjs4x7dtOvPmRLgOMWuIjnDrnBdSqEGULoe256YSxXXfW8AKbnuk +5F6G+TaU33fD6Q3AOfF5u0aOq0NZJ7cguyPpVkAh7DE9ZapD8j3fcEThuk0mEDuY +n/PIjhs4ViFqUZPTkcpG2om3PVODLAgfi49T3f+sHw== +-----END CERTIFICATE----- + +# Issuer: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation +# Subject: CN=Microsoft ECC Root Certificate Authority 2017 O=Microsoft Corporation +# Label: "Microsoft ECC Root Certificate Authority 2017" +# Serial: 136839042543790627607696632466672567020 +# MD5 Fingerprint: dd:a1:03:e6:4a:93:10:d1:bf:f0:19:42:cb:fe:ed:67 +# SHA1 Fingerprint: 99:9a:64:c3:7f:f4:7d:9f:ab:95:f1:47:69:89:14:60:ee:c4:c3:c5 +# SHA256 Fingerprint: 35:8d:f3:9d:76:4a:f9:e1:b7:66:e9:c9:72:df:35:2e:e1:5c:fa:c2:27:af:6a:d1:d7:0e:8e:4a:6e:dc:ba:02 +-----BEGIN CERTIFICATE----- +MIICWTCCAd+gAwIBAgIQZvI9r4fei7FK6gxXMQHC7DAKBggqhkjOPQQDAzBlMQsw +CQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYD +VQQDEy1NaWNyb3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIw +MTcwHhcNMTkxMjE4MjMwNjQ1WhcNNDIwNzE4MjMxNjA0WjBlMQswCQYDVQQGEwJV +UzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1NaWNy +b3NvZnQgRUNDIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwdjAQBgcq +hkjOPQIBBgUrgQQAIgNiAATUvD0CQnVBEyPNgASGAlEvaqiBYgtlzPbKnR5vSmZR +ogPZnZH6thaxjG7efM3beaYvzrvOcS/lpaso7GMEZpn4+vKTEAXhgShC48Zo9OYb +hGBKia/teQ87zvH2RPUBeMCjVDBSMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8E +BTADAQH/MB0GA1UdDgQWBBTIy5lycFIM+Oa+sgRXKSrPQhDtNTAQBgkrBgEEAYI3 +FQEEAwIBADAKBggqhkjOPQQDAwNoADBlAjBY8k3qDPlfXu5gKcs68tvWMoQZP3zV +L8KxzJOuULsJMsbG7X7JNpQS5GiFBqIb0C8CMQCZ6Ra0DvpWSNSkMBaReNtUjGUB +iudQZsIxtzm6uBoiB078a1QWIP8rtedMDE2mT3M= +-----END CERTIFICATE----- + +# Issuer: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation +# Subject: CN=Microsoft RSA Root Certificate Authority 2017 O=Microsoft Corporation +# Label: "Microsoft RSA Root Certificate Authority 2017" +# Serial: 40975477897264996090493496164228220339 +# MD5 Fingerprint: 10:ff:00:ff:cf:c9:f8:c7:7a:c0:ee:35:8e:c9:0f:47 +# SHA1 Fingerprint: 73:a5:e6:4a:3b:ff:83:16:ff:0e:dc:cc:61:8a:90:6e:4e:ae:4d:74 +# SHA256 Fingerprint: c7:41:f7:0f:4b:2a:8d:88:bf:2e:71:c1:41:22:ef:53:ef:10:eb:a0:cf:a5:e6:4c:fa:20:f4:18:85:30:73:e0 +-----BEGIN CERTIFICATE----- +MIIFqDCCA5CgAwIBAgIQHtOXCV/YtLNHcB6qvn9FszANBgkqhkiG9w0BAQwFADBl +MQswCQYDVQQGEwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYw +NAYDVQQDEy1NaWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5 +IDIwMTcwHhcNMTkxMjE4MjI1MTIyWhcNNDIwNzE4MjMwMDIzWjBlMQswCQYDVQQG +EwJVUzEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTYwNAYDVQQDEy1N +aWNyb3NvZnQgUlNBIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTcwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKW76UM4wplZEWCpW9R2LBifOZ +Nt9GkMml7Xhqb0eRaPgnZ1AzHaGm++DlQ6OEAlcBXZxIQIJTELy/xztokLaCLeX0 +ZdDMbRnMlfl7rEqUrQ7eS0MdhweSE5CAg2Q1OQT85elss7YfUJQ4ZVBcF0a5toW1 +HLUX6NZFndiyJrDKxHBKrmCk3bPZ7Pw71VdyvD/IybLeS2v4I2wDwAW9lcfNcztm +gGTjGqwu+UcF8ga2m3P1eDNbx6H7JyqhtJqRjJHTOoI+dkC0zVJhUXAoP8XFWvLJ +jEm7FFtNyP9nTUwSlq31/niol4fX/V4ggNyhSyL71Imtus5Hl0dVe49FyGcohJUc +aDDv70ngNXtk55iwlNpNhTs+VcQor1fznhPbRiefHqJeRIOkpcrVE7NLP8TjwuaG +YaRSMLl6IE9vDzhTyzMMEyuP1pq9KsgtsRx9S1HKR9FIJ3Jdh+vVReZIZZ2vUpC6 +W6IYZVcSn2i51BVrlMRpIpj0M+Dt+VGOQVDJNE92kKz8OMHY4Xu54+OU4UZpyw4K +UGsTuqwPN1q3ErWQgR5WrlcihtnJ0tHXUeOrO8ZV/R4O03QK0dqq6mm4lyiPSMQH ++FJDOvTKVTUssKZqwJz58oHhEmrARdlns87/I6KJClTUFLkqqNfs+avNJVgyeY+Q +W5g5xAgGwax/Dj0ApQIDAQABo1QwUjAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUCctZf4aycI8awznjwNnpv7tNsiMwEAYJKwYBBAGC +NxUBBAMCAQAwDQYJKoZIhvcNAQEMBQADggIBAKyvPl3CEZaJjqPnktaXFbgToqZC +LgLNFgVZJ8og6Lq46BrsTaiXVq5lQ7GPAJtSzVXNUzltYkyLDVt8LkS/gxCP81OC +gMNPOsduET/m4xaRhPtthH80dK2Jp86519efhGSSvpWhrQlTM93uCupKUY5vVau6 +tZRGrox/2KJQJWVggEbbMwSubLWYdFQl3JPk+ONVFT24bcMKpBLBaYVu32TxU5nh +SnUgnZUP5NbcA/FZGOhHibJXWpS2qdgXKxdJ5XbLwVaZOjex/2kskZGT4d9Mozd2 +TaGf+G0eHdP67Pv0RR0Tbc/3WeUiJ3IrhvNXuzDtJE3cfVa7o7P4NHmJweDyAmH3 +pvwPuxwXC65B2Xy9J6P9LjrRk5Sxcx0ki69bIImtt2dmefU6xqaWM/5TkshGsRGR +xpl/j8nWZjEgQRCHLQzWwa80mMpkg/sTV9HB8Dx6jKXB/ZUhoHHBk2dxEuqPiApp +GWSZI1b7rCoucL5mxAyE7+WL85MB+GqQk2dLsmijtWKP6T+MejteD+eMuMZ87zf9 +dOLITzNy4ZQ5bb0Sr74MTnB8G2+NszKTc0QWbej09+CVgI+WXTik9KveCjCHk9hN +AHFiRSdLOkKEW39lt2c0Ui2cFmuqqNh7o0JMcccMyj6D5KbvtwEwXlGjefVwaaZB +RA+GsCyRxj3qrg+E +-----END CERTIFICATE----- + +# Issuer: CN=e-Szigno Root CA 2017 O=Microsec Ltd. +# Subject: CN=e-Szigno Root CA 2017 O=Microsec Ltd. +# Label: "e-Szigno Root CA 2017" +# Serial: 411379200276854331539784714 +# MD5 Fingerprint: de:1f:f6:9e:84:ae:a7:b4:21:ce:1e:58:7d:d1:84:98 +# SHA1 Fingerprint: 89:d4:83:03:4f:9e:9a:48:80:5f:72:37:d4:a9:a6:ef:cb:7c:1f:d1 +# SHA256 Fingerprint: be:b0:0b:30:83:9b:9b:c3:2c:32:e4:44:79:05:95:06:41:f2:64:21:b1:5e:d0:89:19:8b:51:8a:e2:ea:1b:99 +-----BEGIN CERTIFICATE----- +MIICQDCCAeWgAwIBAgIMAVRI7yH9l1kN9QQKMAoGCCqGSM49BAMCMHExCzAJBgNV +BAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMgTHRk +LjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25vIFJv +b3QgQ0EgMjAxNzAeFw0xNzA4MjIxMjA3MDZaFw00MjA4MjIxMjA3MDZaMHExCzAJ +BgNVBAYTAkhVMREwDwYDVQQHDAhCdWRhcGVzdDEWMBQGA1UECgwNTWljcm9zZWMg +THRkLjEXMBUGA1UEYQwOVkFUSFUtMjM1ODQ0OTcxHjAcBgNVBAMMFWUtU3ppZ25v +IFJvb3QgQ0EgMjAxNzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABJbcPYrYsHtv +xie+RJCxs1YVe45DJH0ahFnuY2iyxl6H0BVIHqiQrb1TotreOpCmYF9oMrWGQd+H +Wyx7xf58etqjYzBhMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G +A1UdDgQWBBSHERUI0arBeAyxr87GyZDvvzAEwDAfBgNVHSMEGDAWgBSHERUI0arB +eAyxr87GyZDvvzAEwDAKBggqhkjOPQQDAgNJADBGAiEAtVfd14pVCzbhhkT61Nlo +jbjcI4qKDdQvfepz7L9NbKgCIQDLpbQS+ue16M9+k/zzNY9vTlp8tLxOsvxyqltZ ++efcMQ== +-----END CERTIFICATE----- + +# Issuer: O=CERTSIGN SA OU=certSIGN ROOT CA G2 +# Subject: O=CERTSIGN SA OU=certSIGN ROOT CA G2 +# Label: "certSIGN Root CA G2" +# Serial: 313609486401300475190 +# MD5 Fingerprint: 8c:f1:75:8a:c6:19:cf:94:b7:f7:65:20:87:c3:97:c7 +# SHA1 Fingerprint: 26:f9:93:b4:ed:3d:28:27:b0:b9:4b:a7:e9:15:1d:a3:8d:92:e5:32 +# SHA256 Fingerprint: 65:7c:fe:2f:a7:3f:aa:38:46:25:71:f3:32:a2:36:3a:46:fc:e7:02:09:51:71:07:02:cd:fb:b6:ee:da:33:05 +-----BEGIN CERTIFICATE----- +MIIFRzCCAy+gAwIBAgIJEQA0tk7GNi02MA0GCSqGSIb3DQEBCwUAMEExCzAJBgNV +BAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJR04g +Uk9PVCBDQSBHMjAeFw0xNzAyMDYwOTI3MzVaFw00MjAyMDYwOTI3MzVaMEExCzAJ +BgNVBAYTAlJPMRQwEgYDVQQKEwtDRVJUU0lHTiBTQTEcMBoGA1UECxMTY2VydFNJ +R04gUk9PVCBDQSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDF +dRmRfUR0dIf+DjuW3NgBFszuY5HnC2/OOwppGnzC46+CjobXXo9X69MhWf05N0Iw +vlDqtg+piNguLWkh59E3GE59kdUWX2tbAMI5Qw02hVK5U2UPHULlj88F0+7cDBrZ +uIt4ImfkabBoxTzkbFpG583H+u/E7Eu9aqSs/cwoUe+StCmrqzWaTOTECMYmzPhp +n+Sc8CnTXPnGFiWeI8MgwT0PPzhAsP6CRDiqWhqKa2NYOLQV07YRaXseVO6MGiKs +cpc/I1mbySKEwQdPzH/iV8oScLumZfNpdWO9lfsbl83kqK/20U6o2YpxJM02PbyW +xPFsqa7lzw1uKA2wDrXKUXt4FMMgL3/7FFXhEZn91QqhngLjYl/rNUssuHLoPj1P +rCy7Lobio3aP5ZMqz6WryFyNSwb/EkaseMsUBzXgqd+L6a8VTxaJW732jcZZroiF +DsGJ6x9nxUWO/203Nit4ZoORUSs9/1F3dmKh7Gc+PoGD4FapUB8fepmrY7+EF3fx +DTvf95xhszWYijqy7DwaNz9+j5LP2RIUZNoQAhVB/0/E6xyjyfqZ90bp4RjZsbgy +LcsUDFDYg2WD7rlcz8sFWkz6GZdr1l0T08JcVLwyc6B49fFtHsufpaafItzRUZ6C +eWRgKRM+o/1Pcmqr4tTluCRVLERLiohEnMqE0yo7AgMBAAGjQjBAMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSCIS1mxteg4BXrzkwJ +d8RgnlRuAzANBgkqhkiG9w0BAQsFAAOCAgEAYN4auOfyYILVAzOBywaK8SJJ6ejq +kX/GM15oGQOGO0MBzwdw5AgeZYWR5hEit/UCI46uuR59H35s5r0l1ZUa8gWmr4UC +b6741jH/JclKyMeKqdmfS0mbEVeZkkMR3rYzpMzXjWR91M08KCy0mpbqTfXERMQl +qiCA2ClV9+BB/AYm/7k29UMUA2Z44RGx2iBfRgB4ACGlHgAoYXhvqAEBj500mv/0 +OJD7uNGzcgbJceaBxXntC6Z58hMLnPddDnskk7RI24Zf3lCGeOdA5jGokHZwYa+c +NywRtYK3qq4kNFtyDGkNzVmf9nGvnAvRCjj5BiKDUyUM/FHE5r7iOZULJK2v0ZXk +ltd0ZGtxTgI8qoXzIKNDOXZbbFD+mpwUHmUUihW9o4JFWklWatKcsWMy5WHgUyIO +pwpJ6st+H6jiYoD2EEVSmAYY3qXNL3+q1Ok+CHLsIwMCPKaq2LxndD0UF/tUSxfj +03k9bWtJySgOLnRQvwzZRjoQhsmnP+mg7H/rpXdYaXHmgwo38oZJar55CJD2AhZk +PuXaTH4MNMn5X7azKFGnpyuqSfqNZSlO42sTp5SjLVFteAxEy9/eCG/Oo2Sr05WE +1LlSVHJ7liXMvGnjSG4N0MedJ5qq+BOS3R7fY581qRY27Iy4g/Q9iY/NtBde17MX +QRBdJ3NghVdJIgc= +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global Certification Authority" +# Serial: 1846098327275375458322922162 +# MD5 Fingerprint: f8:1c:18:2d:2f:ba:5f:6d:a1:6c:bc:c7:ab:91:c7:0e +# SHA1 Fingerprint: 2f:8f:36:4f:e1:58:97:44:21:59:87:a5:2a:9a:d0:69:95:26:7f:b5 +# SHA256 Fingerprint: 97:55:20:15:f5:dd:fc:3c:87:88:c0:06:94:45:55:40:88:94:45:00:84:f1:00:86:70:86:bc:1a:2b:b5:8d:c8 +-----BEGIN CERTIFICATE----- +MIIF2jCCA8KgAwIBAgIMBfcOhtpJ80Y1LrqyMA0GCSqGSIb3DQEBCwUAMIGIMQsw +CQYDVQQGEwJVUzERMA8GA1UECAwISWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28x +ITAfBgNVBAoMGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1 +c3R3YXZlIEdsb2JhbCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0xNzA4MjMx +OTM0MTJaFw00MjA4MjMxOTM0MTJaMIGIMQswCQYDVQQGEwJVUzERMA8GA1UECAwI +SWxsaW5vaXMxEDAOBgNVBAcMB0NoaWNhZ28xITAfBgNVBAoMGFRydXN0d2F2ZSBI +b2xkaW5ncywgSW5jLjExMC8GA1UEAwwoVHJ1c3R3YXZlIEdsb2JhbCBDZXJ0aWZp +Y2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB +ALldUShLPDeS0YLOvR29zd24q88KPuFd5dyqCblXAj7mY2Hf8g+CY66j96xz0Xzn +swuvCAAJWX/NKSqIk4cXGIDtiLK0thAfLdZfVaITXdHG6wZWiYj+rDKd/VzDBcdu +7oaJuogDnXIhhpCujwOl3J+IKMujkkkP7NAP4m1ET4BqstTnoApTAbqOl5F2brz8 +1Ws25kCI1nsvXwXoLG0R8+eyvpJETNKXpP7ScoFDB5zpET71ixpZfR9oWN0EACyW +80OzfpgZdNmcc9kYvkHHNHnZ9GLCQ7mzJ7Aiy/k9UscwR7PJPrhq4ufogXBeQotP +JqX+OsIgbrv4Fo7NDKm0G2x2EOFYeUY+VM6AqFcJNykbmROPDMjWLBz7BegIlT1l +RtzuzWniTY+HKE40Cz7PFNm73bZQmq131BnW2hqIyE4bJ3XYsgjxroMwuREOzYfw +hI0Vcnyh78zyiGG69Gm7DIwLdVcEuE4qFC49DxweMqZiNu5m4iK4BUBjECLzMx10 +coos9TkpoNPnG4CELcU9402x/RpvumUHO1jsQkUm+9jaJXLE9gCxInm943xZYkqc +BW89zubWR2OZxiRvchLIrH+QtAuRcOi35hYQcRfO3gZPSEF9NUqjifLJS3tBEW1n +twiYTOURGa5CgNz7kAXU+FDKvuStx8KU1xad5hePrzb7AgMBAAGjQjBAMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFJngGWcNYtt2s9o9uFvo/ULSMQ6HMA4GA1Ud +DwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAmHNw4rDT7TnsTGDZqRKGFx6W +0OhUKDtkLSGm+J1WE2pIPU/HPinbbViDVD2HfSMF1OQc3Og4ZYbFdada2zUFvXfe +uyk3QAUHw5RSn8pk3fEbK9xGChACMf1KaA0HZJDmHvUqoai7PF35owgLEQzxPy0Q +lG/+4jSHg9bP5Rs1bdID4bANqKCqRieCNqcVtgimQlRXtpla4gt5kNdXElE1GYhB +aCXUNxeEFfsBctyV3lImIJgm4nb1J2/6ADtKYdkNy1GTKv0WBpanI5ojSP5RvbbE +sLFUzt5sQa0WZ37b/TjNuThOssFgy50X31ieemKyJo90lZvkWx3SD92YHJtZuSPT +MaCm/zjdzyBP6VhWOmfD0faZmZ26NraAL4hHT4a/RDqA5Dccprrql5gR0IRiR2Qe +qu5AvzSxnI9O4fKSTx+O856X3vOmeWqJcU9LJxdI/uz0UA9PSX3MReO9ekDFQdxh +VicGaeVyQYHTtgGJoC86cnn+OjC/QezHYj6RS8fZMXZC+fc8Y+wmjHMMfRod6qh8 +h6jCJ3zhM0EPz8/8AKAigJ5Kp28AsEFFtyLKaEjFQqKu3R3y4G5OBVixwJAWKqQ9 +EEC+j2Jjg6mcgn0tAumDMHzLJ8n9HmYAsC7TIS+OMxZsmO0QqAfWzJPP29FpHOTK +yeC2nOnOcXHebD8WpHk= +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global ECC P256 Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global ECC P256 Certification Authority" +# Serial: 4151900041497450638097112925 +# MD5 Fingerprint: 5b:44:e3:8d:5d:36:86:26:e8:0d:05:d2:59:a7:83:54 +# SHA1 Fingerprint: b4:90:82:dd:45:0c:be:8b:5b:b1:66:d3:e2:a4:08:26:cd:ed:42:cf +# SHA256 Fingerprint: 94:5b:bc:82:5e:a5:54:f4:89:d1:fd:51:a7:3d:df:2e:a6:24:ac:70:19:a0:52:05:22:5c:22:a7:8c:cf:a8:b4 +-----BEGIN CERTIFICATE----- +MIICYDCCAgegAwIBAgIMDWpfCD8oXD5Rld9dMAoGCCqGSM49BAMCMIGRMQswCQYD +VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf +BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 +YXZlIEdsb2JhbCBFQ0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x +NzA4MjMxOTM1MTBaFw00MjA4MjMxOTM1MTBaMIGRMQswCQYDVQQGEwJVUzERMA8G +A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 +d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF +Q0MgUDI1NiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTBZMBMGByqGSM49AgEGCCqG +SM49AwEHA0IABH77bOYj43MyCMpg5lOcunSNGLB4kFKA3TjASh3RqMyTpJcGOMoN +FWLGjgEqZZ2q3zSRLoHB5DOSMcT9CTqmP62jQzBBMA8GA1UdEwEB/wQFMAMBAf8w +DwYDVR0PAQH/BAUDAwcGADAdBgNVHQ4EFgQUo0EGrJBt0UrrdaVKEJmzsaGLSvcw +CgYIKoZIzj0EAwIDRwAwRAIgB+ZU2g6gWrKuEZ+Hxbb/ad4lvvigtwjzRM4q3wgh +DDcCIC0mA6AFvWvR9lz4ZcyGbbOcNEhjhAnFjXca4syc4XR7 +-----END CERTIFICATE----- + +# Issuer: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. +# Subject: CN=Trustwave Global ECC P384 Certification Authority O=Trustwave Holdings, Inc. +# Label: "Trustwave Global ECC P384 Certification Authority" +# Serial: 2704997926503831671788816187 +# MD5 Fingerprint: ea:cf:60:c4:3b:b9:15:29:40:a1:97:ed:78:27:93:d6 +# SHA1 Fingerprint: e7:f3:a3:c8:cf:6f:c3:04:2e:6d:0e:67:32:c5:9e:68:95:0d:5e:d2 +# SHA256 Fingerprint: 55:90:38:59:c8:c0:c3:eb:b8:75:9e:ce:4e:25:57:22:5f:f5:75:8b:bd:38:eb:d4:82:76:60:1e:1b:d5:80:97 +-----BEGIN CERTIFICATE----- +MIICnTCCAiSgAwIBAgIMCL2Fl2yZJ6SAaEc7MAoGCCqGSM49BAMDMIGRMQswCQYD +VQQGEwJVUzERMA8GA1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAf +BgNVBAoTGFRydXN0d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3 +YXZlIEdsb2JhbCBFQ0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0x +NzA4MjMxOTM2NDNaFw00MjA4MjMxOTM2NDNaMIGRMQswCQYDVQQGEwJVUzERMA8G +A1UECBMISWxsaW5vaXMxEDAOBgNVBAcTB0NoaWNhZ28xITAfBgNVBAoTGFRydXN0 +d2F2ZSBIb2xkaW5ncywgSW5jLjE6MDgGA1UEAxMxVHJ1c3R3YXZlIEdsb2JhbCBF +Q0MgUDM4NCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTB2MBAGByqGSM49AgEGBSuB +BAAiA2IABGvaDXU1CDFHBa5FmVXxERMuSvgQMSOjfoPTfygIOiYaOs+Xgh+AtycJ +j9GOMMQKmw6sWASr9zZ9lCOkmwqKi6vr/TklZvFe/oyujUF5nQlgziip04pt89ZF +1PKYhDhloKNDMEEwDwYDVR0TAQH/BAUwAwEB/zAPBgNVHQ8BAf8EBQMDBwYAMB0G +A1UdDgQWBBRVqYSJ0sEyvRjLbKYHTsjnnb6CkDAKBggqhkjOPQQDAwNnADBkAjA3 +AZKXRRJ+oPM+rRk6ct30UJMDEr5E0k9BpIycnR+j9sKS50gU/k6bpZFXrsY3crsC +MGclCrEMXu6pY5Jv5ZAL/mYiykf9ijH3g/56vxC+GCsej/YpHpRZ744hN8tRmKVu +Sw== +-----END CERTIFICATE----- + +# Issuer: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. +# Subject: CN=NAVER Global Root Certification Authority O=NAVER BUSINESS PLATFORM Corp. +# Label: "NAVER Global Root Certification Authority" +# Serial: 9013692873798656336226253319739695165984492813 +# MD5 Fingerprint: c8:7e:41:f6:25:3b:f5:09:b3:17:e8:46:3d:bf:d0:9b +# SHA1 Fingerprint: 8f:6b:f2:a9:27:4a:da:14:a0:c4:f4:8e:61:27:f9:c0:1e:78:5d:d1 +# SHA256 Fingerprint: 88:f4:38:dc:f8:ff:d1:fa:8f:42:91:15:ff:e5:f8:2a:e1:e0:6e:0c:70:c3:75:fa:ad:71:7b:34:a4:9e:72:65 +-----BEGIN CERTIFICATE----- +MIIFojCCA4qgAwIBAgIUAZQwHqIL3fXFMyqxQ0Rx+NZQTQ0wDQYJKoZIhvcNAQEM +BQAwaTELMAkGA1UEBhMCS1IxJjAkBgNVBAoMHU5BVkVSIEJVU0lORVNTIFBMQVRG +T1JNIENvcnAuMTIwMAYDVQQDDClOQVZFUiBHbG9iYWwgUm9vdCBDZXJ0aWZpY2F0 +aW9uIEF1dGhvcml0eTAeFw0xNzA4MTgwODU4NDJaFw0zNzA4MTgyMzU5NTlaMGkx +CzAJBgNVBAYTAktSMSYwJAYDVQQKDB1OQVZFUiBCVVNJTkVTUyBQTEFURk9STSBD +b3JwLjEyMDAGA1UEAwwpTkFWRVIgR2xvYmFsIFJvb3QgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC21PGTXLVA +iQqrDZBbUGOukJR0F0Vy1ntlWilLp1agS7gvQnXp2XskWjFlqxcX0TM62RHcQDaH +38dq6SZeWYp34+hInDEW+j6RscrJo+KfziFTowI2MMtSAuXaMl3Dxeb57hHHi8lE +HoSTGEq0n+USZGnQJoViAbbJAh2+g1G7XNr4rRVqmfeSVPc0W+m/6imBEtRTkZaz +kVrd/pBzKPswRrXKCAfHcXLJZtM0l/aM9BhK4dA9WkW2aacp+yPOiNgSnABIqKYP +szuSjXEOdMWLyEz59JuOuDxp7W87UC9Y7cSw0BwbagzivESq2M0UXZR4Yb8Obtoq +vC8MC3GmsxY/nOb5zJ9TNeIDoKAYv7vxvvTWjIcNQvcGufFt7QSUqP620wbGQGHf +nZ3zVHbOUzoBppJB7ASjjw2i1QnK1sua8e9DXcCrpUHPXFNwcMmIpi3Ua2FzUCaG +YQ5fG8Ir4ozVu53BA0K6lNpfqbDKzE0K70dpAy8i+/Eozr9dUGWokG2zdLAIx6yo +0es+nPxdGoMuK8u180SdOqcXYZaicdNwlhVNt0xz7hlcxVs+Qf6sdWA7G2POAN3a +CJBitOUt7kinaxeZVL6HSuOpXgRM6xBtVNbv8ejyYhbLgGvtPe31HzClrkvJE+2K +AQHJuFFYwGY6sWZLxNUxAmLpdIQM201GLQIDAQABo0IwQDAdBgNVHQ4EFgQU0p+I +36HNLL3s9TsBAZMzJ7LrYEswDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMB +Af8wDQYJKoZIhvcNAQEMBQADggIBADLKgLOdPVQG3dLSLvCkASELZ0jKbY7gyKoN +qo0hV4/GPnrK21HUUrPUloSlWGB/5QuOH/XcChWB5Tu2tyIvCZwTFrFsDDUIbatj +cu3cvuzHV+YwIHHW1xDBE1UBjCpD5EHxzzp6U5LOogMFDTjfArsQLtk70pt6wKGm ++LUx5vR1yblTmXVHIloUFcd4G7ad6Qz4G3bxhYTeodoS76TiEJd6eN4MUZeoIUCL +hr0N8F5OSza7OyAfikJW4Qsav3vQIkMsRIz75Sq0bBwcupTgE34h5prCy8VCZLQe +lHsIJchxzIdFV4XTnyliIoNRlwAYl3dqmJLJfGBs32x9SuRwTMKeuB330DTHD8z7 +p/8Dvq1wkNoL3chtl1+afwkyQf3NosxabUzyqkn+Zvjp2DXrDige7kgvOtB5CTh8 +piKCk5XQA76+AqAF3SAi428diDRgxuYKuQl1C/AH6GmWNcf7I4GOODm4RStDeKLR +LBT/DShycpWbXgnbiUSYqqFJu3FS8r/2/yehNq+4tneI3TqkbZs0kNwUXTC/t+sX +5Ie3cdCh13cV1ELX8vMxmV2b3RZtP+oGI/hGoiLtk/bdmuYqh7GYVPEi92tF4+KO +dh2ajcQGjTa3FPOdVGm3jjzVpG2Tgbet9r1ke8LJaDmgkpzNNIaRkPpkUZ3+/uul +9XXeifdy +-----END CERTIFICATE----- + +# Issuer: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Subject: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres +# Label: "AC RAIZ FNMT-RCM SERVIDORES SEGUROS" +# Serial: 131542671362353147877283741781055151509 +# MD5 Fingerprint: 19:36:9c:52:03:2f:d2:d1:bb:23:cc:dd:1e:12:55:bb +# SHA1 Fingerprint: 62:ff:d9:9e:c0:65:0d:03:ce:75:93:d2:ed:3f:2d:32:c9:e3:e5:4a +# SHA256 Fingerprint: 55:41:53:b1:3d:2c:f9:dd:b7:53:bf:be:1a:4e:0a:e0:8d:0a:a4:18:70:58:fe:60:a2:b8:62:b2:e4:b8:7b:cb +-----BEGIN CERTIFICATE----- +MIICbjCCAfOgAwIBAgIQYvYybOXE42hcG2LdnC6dlTAKBggqhkjOPQQDAzB4MQsw +CQYDVQQGEwJFUzERMA8GA1UECgwIRk5NVC1SQ00xDjAMBgNVBAsMBUNlcmVzMRgw +FgYDVQRhDA9WQVRFUy1RMjgyNjAwNEoxLDAqBgNVBAMMI0FDIFJBSVogRk5NVC1S +Q00gU0VSVklET1JFUyBTRUdVUk9TMB4XDTE4MTIyMDA5MzczM1oXDTQzMTIyMDA5 +MzczM1oweDELMAkGA1UEBhMCRVMxETAPBgNVBAoMCEZOTVQtUkNNMQ4wDAYDVQQL +DAVDZXJlczEYMBYGA1UEYQwPVkFURVMtUTI4MjYwMDRKMSwwKgYDVQQDDCNBQyBS +QUlaIEZOTVQtUkNNIFNFUlZJRE9SRVMgU0VHVVJPUzB2MBAGByqGSM49AgEGBSuB +BAAiA2IABPa6V1PIyqvfNkpSIeSX0oNnnvBlUdBeh8dHsVnyV0ebAAKTRBdp20LH +sbI6GA60XYyzZl2hNPk2LEnb80b8s0RpRBNm/dfF/a82Tc4DTQdxz69qBdKiQ1oK +Um8BA06Oi6NCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFAG5L++/EYZg8k/QQW6rcx/n0m5JMAoGCCqGSM49BAMDA2kAMGYCMQCu +SuMrQMN0EfKVrRYj3k4MGuZdpSRea0R7/DjiT8ucRRcRTBQnJlU5dUoDzBOQn5IC +MQD6SmxgiHPz7riYYqnOK8LZiqZwMR2vsJRM60/G49HzYqc8/5MuB1xJAWdpEgJy +v+c= +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root R46 O=GlobalSign nv-sa +# Label: "GlobalSign Root R46" +# Serial: 1552617688466950547958867513931858518042577 +# MD5 Fingerprint: c4:14:30:e4:fa:66:43:94:2a:6a:1b:24:5f:19:d0:ef +# SHA1 Fingerprint: 53:a2:b0:4b:ca:6b:d6:45:e6:39:8a:8e:c4:0d:d2:bf:77:c3:a2:90 +# SHA256 Fingerprint: 4f:a3:12:6d:8d:3a:11:d1:c4:85:5a:4f:80:7c:ba:d6:cf:91:9d:3a:5a:88:b0:3b:ea:2c:63:72:d9:3c:40:c9 +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgISEdK7udcjGJ5AXwqdLdDfJWfRMA0GCSqGSIb3DQEBDAUA +MEYxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYD +VQQDExNHbG9iYWxTaWduIFJvb3QgUjQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMy +MDAwMDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYt +c2ExHDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB +AQUAA4ICDwAwggIKAoICAQCsrHQy6LNl5brtQyYdpokNRbopiLKkHWPd08EsCVeJ +OaFV6Wc0dwxu5FUdUiXSE2te4R2pt32JMl8Nnp8semNgQB+msLZ4j5lUlghYruQG +vGIFAha/r6gjA7aUD7xubMLL1aa7DOn2wQL7Id5m3RerdELv8HQvJfTqa1VbkNud +316HCkD7rRlr+/fKYIje2sGP1q7Vf9Q8g+7XFkyDRTNrJ9CG0Bwta/OrffGFqfUo +0q3v84RLHIf8E6M6cqJaESvWJ3En7YEtbWaBkoe0G1h6zD8K+kZPTXhc+CtI4wSE +y132tGqzZfxCnlEmIyDLPRT5ge1lFgBPGmSXZgjPjHvjK8Cd+RTyG/FWaha/LIWF +zXg4mutCagI0GIMXTpRW+LaCtfOW3T3zvn8gdz57GSNrLNRyc0NXfeD412lPFzYE ++cCQYDdF3uYM2HSNrpyibXRdQr4G9dlkbgIQrImwTDsHTUB+JMWKmIJ5jqSngiCN +I/onccnfxkF0oE32kRbcRoxfKWMxWXEM2G/CtjJ9++ZdU6Z+Ffy7dXxd7Pj2Fxzs +x2sZy/N78CsHpdlseVR2bJ0cpm4O6XkMqCNqo98bMDGfsVR7/mrLZqrcZdCinkqa +ByFrgY/bxFn63iLABJzjqls2k+g9vXqhnQt2sQvHnf3PmKgGwvgqo6GDoLclcqUC +4wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV +HQ4EFgQUA1yrc4GHqMywptWU4jaWSf8FmSwwDQYJKoZIhvcNAQEMBQADggIBAHx4 +7PYCLLtbfpIrXTncvtgdokIzTfnvpCo7RGkerNlFo048p9gkUbJUHJNOxO97k4Vg +JuoJSOD1u8fpaNK7ajFxzHmuEajwmf3lH7wvqMxX63bEIaZHU1VNaL8FpO7XJqti +2kM3S+LGteWygxk6x9PbTZ4IevPuzz5i+6zoYMzRx6Fcg0XERczzF2sUyQQCPtIk +pnnpHs6i58FZFZ8d4kuaPp92CC1r2LpXFNqD6v6MVenQTqnMdzGxRBF6XLE+0xRF +FRhiJBPSy03OXIPBNvIQtQ6IbbjhVp+J3pZmOUdkLG5NrmJ7v2B0GbhWrJKsFjLt +rWhV/pi60zTe9Mlhww6G9kuEYO4Ne7UyWHmRVSyBQ7N0H3qqJZ4d16GLuc1CLgSk +ZoNNiTW2bKg2SnkheCLQQrzRQDGQob4Ez8pn7fXwgNNgyYMqIgXQBztSvwyeqiv5 +u+YfjyW6hY0XHgL+XVAEV8/+LbzvXMAaq7afJMbfc2hIkCwU9D9SGuTSyxTDYWnP +4vkYxboznxSjBF25cfe1lNj2M8FawTSLfJvdkzrnE6JwYZ+vj+vYxXX4M2bUdGc6 +N3ec592kD3ZDZopD8p/7DEJ4Y9HiD2971KE9dJeFt0g5QdYg/NA6s/rob8SKunE3 +vouXsXgxT7PntgMTzlSdriVZzH81Xwj3QEUxeCp6 +-----END CERTIFICATE----- + +# Issuer: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Subject: CN=GlobalSign Root E46 O=GlobalSign nv-sa +# Label: "GlobalSign Root E46" +# Serial: 1552617690338932563915843282459653771421763 +# MD5 Fingerprint: b5:b8:66:ed:de:08:83:e3:c9:e2:01:34:06:ac:51:6f +# SHA1 Fingerprint: 39:b4:6c:d5:fe:80:06:eb:e2:2f:4a:bb:08:33:a0:af:db:b9:dd:84 +# SHA256 Fingerprint: cb:b9:c4:4d:84:b8:04:3e:10:50:ea:31:a6:9f:51:49:55:d7:bf:d2:e2:c6:b4:93:01:01:9a:d6:1d:9f:50:58 +-----BEGIN CERTIFICATE----- +MIICCzCCAZGgAwIBAgISEdK7ujNu1LzmJGjFDYQdmOhDMAoGCCqGSM49BAMDMEYx +CzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYDVQQD +ExNHbG9iYWxTaWduIFJvb3QgRTQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMyMDAw +MDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2Ex +HDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAScDrHPt+ieUnd1NPqlRqetMhkytAepJ8qUuwzSChDH2omwlwxwEwkBjtjq +R+q+soArzfwoDdusvKSGN+1wCAB16pMLey5SnCNoIwZD7JIvU4Tb+0cUB+hflGdd +yXqBPCCjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud +DgQWBBQxCpCPtsad0kRLgLWi5h+xEk8blTAKBggqhkjOPQQDAwNoADBlAjEA31SQ +7Zvvi5QCkxeCmb6zniz2C5GMn0oUsfZkvLtoURMMA/cVi4RguYv/Uo7njLwcAjA8 ++RHUjE7AwWHCFUyqqx0LMV87HOIAl0Qx5v5zli/altP+CAezNIm8BZ/3Hobui3A= +-----END CERTIFICATE----- + +# Issuer: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH +# Subject: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH +# Label: "GLOBALTRUST 2020" +# Serial: 109160994242082918454945253 +# MD5 Fingerprint: 8a:c7:6f:cb:6d:e3:cc:a2:f1:7c:83:fa:0e:78:d7:e8 +# SHA1 Fingerprint: d0:67:c1:13:51:01:0c:aa:d0:c7:6a:65:37:31:16:26:4f:53:71:a2 +# SHA256 Fingerprint: 9a:29:6a:51:82:d1:d4:51:a2:e3:7f:43:9b:74:da:af:a2:67:52:33:29:f9:0f:9a:0d:20:07:c3:34:e2:3c:9a +-----BEGIN CERTIFICATE----- +MIIFgjCCA2qgAwIBAgILWku9WvtPilv6ZeUwDQYJKoZIhvcNAQELBQAwTTELMAkG +A1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9uaXRvcmluZyBHbWJIMRkw +FwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMB4XDTIwMDIxMDAwMDAwMFoXDTQwMDYx +MDAwMDAwMFowTTELMAkGA1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9u +aXRvcmluZyBHbWJIMRkwFwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMIICIjANBgkq +hkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAri5WrRsc7/aVj6B3GyvTY4+ETUWiD59b +RatZe1E0+eyLinjF3WuvvcTfk0Uev5E4C64OFudBc/jbu9G4UeDLgztzOG53ig9Z +YybNpyrOVPu44sB8R85gfD+yc/LAGbaKkoc1DZAoouQVBGM+uq/ufF7MpotQsjj3 +QWPKzv9pj2gOlTblzLmMCcpL3TGQlsjMH/1WljTbjhzqLL6FLmPdqqmV0/0plRPw +yJiT2S0WR5ARg6I6IqIoV6Lr/sCMKKCmfecqQjuCgGOlYx8ZzHyyZqjC0203b+J+ +BlHZRYQfEs4kUmSFC0iAToexIiIwquuuvuAC4EDosEKAA1GqtH6qRNdDYfOiaxaJ +SaSjpCuKAsR49GiKweR6NrFvG5Ybd0mN1MkGco/PU+PcF4UgStyYJ9ORJitHHmkH +r96i5OTUawuzXnzUJIBHKWk7buis/UDr2O1xcSvy6Fgd60GXIsUf1DnQJ4+H4xj0 +4KlGDfV0OoIu0G4skaMxXDtG6nsEEFZegB31pWXogvziB4xiRfUg3kZwhqG8k9Me +dKZssCz3AwyIDMvUclOGvGBG85hqwvG/Q/lwIHfKN0F5VVJjjVsSn8VoxIidrPIw +q7ejMZdnrY8XD2zHc+0klGvIg5rQmjdJBKuxFshsSUktq6HQjJLyQUp5ISXbY9e2 +nKd+Qmn7OmMCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwHQYDVR0OBBYEFNwuH9FhN3nkq9XVsxJxaD1qaJwiMB8GA1UdIwQYMBaAFNwu +H9FhN3nkq9XVsxJxaD1qaJwiMA0GCSqGSIb3DQEBCwUAA4ICAQCR8EICaEDuw2jA +VC/f7GLDw56KoDEoqoOOpFaWEhCGVrqXctJUMHytGdUdaG/7FELYjQ7ztdGl4wJC +XtzoRlgHNQIw4Lx0SsFDKv/bGtCwr2zD/cuz9X9tAy5ZVp0tLTWMstZDFyySCstd +6IwPS3BD0IL/qMy/pJTAvoe9iuOTe8aPmxadJ2W8esVCgmxcB9CpwYhgROmYhRZf ++I/KARDOJcP5YBugxZfD0yyIMaK9MOzQ0MAS8cE54+X1+NZK3TTN+2/BT+MAi1bi +kvcoskJ3ciNnxz8RFbLEAwW+uxF7Cr+obuf/WEPPm2eggAe2HcqtbepBEX4tdJP7 +wry+UUTF72glJ4DjyKDUEuzZpTcdN3y0kcra1LGWge9oXHYQSa9+pTeAsRxSvTOB +TI/53WXZFM2KJVj04sWDpQmQ1GwUY7VA3+vA/MRYfg0UFodUJ25W5HCEuGwyEn6C +MUO+1918oa2u1qsgEu8KwxCMSZY13At1XrFP1U80DhEgB3VDRemjEdqso5nCtnkn +4rnvyOL2NSl6dPrFf4IFYqYK6miyeUcGbvJXqBUzxvd4Sj1Ce2t+/vdG6tHrju+I +aFvowdlxfv1k7/9nR4hYJS8+hge9+6jlgqispdNpQ80xiEmEU5LAsTkbOYMBMMTy +qfrQA71yN2BWHzZ8vTmR9W0Nv3vXkg== +-----END CERTIFICATE----- + +# Issuer: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Subject: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz +# Label: "ANF Secure Server Root CA" +# Serial: 996390341000653745 +# MD5 Fingerprint: 26:a6:44:5a:d9:af:4e:2f:b2:1d:b6:65:b0:4e:e8:96 +# SHA1 Fingerprint: 5b:6e:68:d0:cc:15:b6:a0:5f:1e:c1:5f:ae:02:fc:6b:2f:5d:6f:74 +# SHA256 Fingerprint: fb:8f:ec:75:91:69:b9:10:6b:1e:51:16:44:c6:18:c5:13:04:37:3f:6c:06:43:08:8d:8b:ef:fd:1b:99:75:99 +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum EC-384 CA" +# Serial: 160250656287871593594747141429395092468 +# MD5 Fingerprint: b6:65:b3:96:60:97:12:a1:ec:4e:e1:3d:a3:c6:c9:f1 +# SHA1 Fingerprint: f3:3e:78:3c:ac:df:f4:a2:cc:ac:67:55:69:56:d7:e5:16:3c:e1:ed +# SHA256 Fingerprint: 6b:32:80:85:62:53:18:aa:50:d1:73:c9:8d:8b:da:09:d5:7e:27:41:3d:11:4c:f7:87:a0:f5:d0:6c:03:0c:f6 +-----BEGIN CERTIFICATE----- +MIICZTCCAeugAwIBAgIQeI8nXIESUiClBNAt3bpz9DAKBggqhkjOPQQDAzB0MQsw +CQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBTLkEuMScw +JQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAXBgNVBAMT +EENlcnR1bSBFQy0zODQgQ0EwHhcNMTgwMzI2MDcyNDU0WhcNNDMwMzI2MDcyNDU0 +WjB0MQswCQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBT +LkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAX +BgNVBAMTEENlcnR1bSBFQy0zODQgQ0EwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATE +KI6rGFtqvm5kN2PkzeyrOvfMobgOgknXhimfoZTy42B4mIF4Bk3y7JoOV2CDn7Tm +Fy8as10CW4kjPMIRBSqniBMY81CE1700LCeJVf/OTOffph8oxPBUw7l8t1Ot68Kj +QjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI0GZnQkdjrzife81r1HfS+8 +EF9LMA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNoADBlAjADVS2m5hjEfO/J +UG7BJw+ch69u1RsIGL2SKcHvlJF40jocVYli5RsJHrpka/F2tNQCMQC0QoSZ/6vn +nvuRlydd3LBbMHHOXjgaatkl5+r3YZJW+OraNsKHZZYuciUvf9/DE8k= +-----END CERTIFICATE----- + +# Issuer: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Subject: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority +# Label: "Certum Trusted Root CA" +# Serial: 40870380103424195783807378461123655149 +# MD5 Fingerprint: 51:e1:c2:e7:fe:4c:84:af:59:0e:2f:f4:54:6f:ea:29 +# SHA1 Fingerprint: c8:83:44:c0:18:ae:9f:cc:f1:87:b7:8f:22:d1:c5:d7:45:84:ba:e5 +# SHA256 Fingerprint: fe:76:96:57:38:55:77:3e:37:a9:5e:7a:d4:d9:cc:96:c3:01:57:c1:5d:31:76:5b:a9:b1:57:04:e1:ae:78:fd +-----BEGIN CERTIFICATE----- +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 +-----END CERTIFICATE----- + +# Issuer: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Subject: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique +# Label: "TunTrust Root CA" +# Serial: 108534058042236574382096126452369648152337120275 +# MD5 Fingerprint: 85:13:b9:90:5b:36:5c:b6:5e:b8:5a:f8:e0:31:57:b4 +# SHA1 Fingerprint: cf:e9:70:84:0f:e0:73:0f:9d:f6:0c:7f:2c:4b:ee:20:46:34:9c:bb +# SHA256 Fingerprint: 2e:44:10:2a:b5:8c:b8:54:19:45:1c:8e:19:d9:ac:f3:66:2c:af:bc:61:4b:6a:53:96:0a:30:f7:d0:e2:eb:41 +-----BEGIN CERTIFICATE----- +MIIFszCCA5ugAwIBAgIUEwLV4kBMkkaGFmddtLu7sms+/BMwDQYJKoZIhvcNAQEL +BQAwYTELMAkGA1UEBhMCVE4xNzA1BgNVBAoMLkFnZW5jZSBOYXRpb25hbGUgZGUg +Q2VydGlmaWNhdGlvbiBFbGVjdHJvbmlxdWUxGTAXBgNVBAMMEFR1blRydXN0IFJv +b3QgQ0EwHhcNMTkwNDI2MDg1NzU2WhcNNDQwNDI2MDg1NzU2WjBhMQswCQYDVQQG +EwJUTjE3MDUGA1UECgwuQWdlbmNlIE5hdGlvbmFsZSBkZSBDZXJ0aWZpY2F0aW9u +IEVsZWN0cm9uaXF1ZTEZMBcGA1UEAwwQVHVuVHJ1c3QgUm9vdCBDQTCCAiIwDQYJ +KoZIhvcNAQEBBQADggIPADCCAgoCggIBAMPN0/y9BFPdDCA61YguBUtB9YOCfvdZ +n56eY+hz2vYGqU8ftPkLHzmMmiDQfgbU7DTZhrx1W4eI8NLZ1KMKsmwb60ksPqxd +2JQDoOw05TDENX37Jk0bbjBU2PWARZw5rZzJJQRNmpA+TkBuimvNKWfGzC3gdOgF +VwpIUPp6Q9p+7FuaDmJ2/uqdHYVy7BG7NegfJ7/Boce7SBbdVtfMTqDhuazb1YMZ +GoXRlJfXyqNlC/M4+QKu3fZnz8k/9YosRxqZbwUN/dAdgjH8KcwAWJeRTIAAHDOF +li/LQcKLEITDCSSJH7UP2dl3RxiSlGBcx5kDPP73lad9UKGAwqmDrViWVSHbhlnU +r8a83YFuB9tgYv7sEG7aaAH0gxupPqJbI9dkxt/con3YS7qC0lH4Zr8GRuR5KiY2 +eY8fTpkdso8MDhz/yV3A/ZAQprE38806JG60hZC/gLkMjNWb1sjxVj8agIl6qeIb +MlEsPvLfe/ZdeikZjuXIvTZxi11Mwh0/rViizz1wTaZQmCXcI/m4WEEIcb9PuISg +jwBUFfyRbVinljvrS5YnzWuioYasDXxU5mZMZl+QviGaAkYt5IPCgLnPSz7ofzwB +7I9ezX/SKEIBlYrilz0QIX32nRzFNKHsLA4KUiwSVXAkPcvCFDVDXSdOvsC9qnyW +5/yeYa1E0wCXAgMBAAGjYzBhMB0GA1UdDgQWBBQGmpsfU33x9aTI04Y+oXNZtPdE +ITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFAaamx9TffH1pMjThj6hc1m0 +90QhMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAqgVutt0Vyb+z +xiD2BkewhpMl0425yAA/l/VSJ4hxyXT968pk21vvHl26v9Hr7lxpuhbI87mP0zYu +QEkHDVneixCwSQXi/5E/S7fdAo74gShczNxtr18UnH1YeA32gAm56Q6XKRm4t+v4 +FstVEuTGfbvE7Pi1HE4+Z7/FXxttbUcoqgRYYdZ2vyJ/0Adqp2RT8JeNnYA/u8EH +22Wv5psymsNUk8QcCMNE+3tjEUPRahphanltkE8pjkcFwRJpadbGNjHh/PqAulxP +xOu3Mqz4dWEX1xAZufHSCe96Qp1bWgvUxpVOKs7/B9dPfhgGiPEZtdmYu65xxBzn +dFlY7wyJz4sfdZMaBBSSSFCp61cpABbjNhzI+L/wM9VBD8TMPN3pM0MBkRArHtG5 +Xc0yGYuPjCB31yLEQtyEFpslbei0VXF/sHyz03FJuc9SpAQ/3D2gu68zngowYI7b +nV2UqL1g52KAdoGDDIzMMEZJ4gzSqK/rYXHv5yJiqfdcZGyfFoxnNidF9Ql7v/YQ +CvGwjVRDjAS6oz/v4jXH+XTgbzRB0L9zZVcg+ZtnemZoJE6AZb0QmQZZ8mWvuMZH +u/2QeItBcy6vVR/cO5JyboTT0GFMDcx2V+IthSIVNg3rAZ3r2OvEhJn7wAzMMujj +d9qDRIueVSjAi1jTkD5OGwDxFa2DK5o= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS RSA Root CA 2021" +# Serial: 76817823531813593706434026085292783742 +# MD5 Fingerprint: 65:47:9b:58:86:dd:2c:f0:fc:a2:84:1f:1e:96:c4:91 +# SHA1 Fingerprint: 02:2d:05:82:fa:88:ce:14:0c:06:79:de:7f:14:10:e9:45:d7:a5:6d +# SHA256 Fingerprint: d9:5d:0e:8e:da:79:52:5b:f9:be:b1:1b:14:d2:10:0d:32:94:98:5f:0c:62:d9:fa:bd:9c:d9:99:ec:cb:7b:1d +-----BEGIN CERTIFICATE----- +MIIFpDCCA4ygAwIBAgIQOcqTHO9D88aOk8f0ZIk4fjANBgkqhkiG9w0BAQsFADBs +MQswCQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl +c2VhcmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBSU0Eg +Um9vdCBDQSAyMDIxMB4XDTIxMDIxOTEwNTUzOFoXDTQ1MDIxMzEwNTUzN1owbDEL +MAkGA1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl +YXJjaCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgUlNBIFJv +b3QgQ0EgMjAyMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAIvC569l +mwVnlskNJLnQDmT8zuIkGCyEf3dRywQRNrhe7Wlxp57kJQmXZ8FHws+RFjZiPTgE +4VGC/6zStGndLuwRo0Xua2s7TL+MjaQenRG56Tj5eg4MmOIjHdFOY9TnuEFE+2uv +a9of08WRiFukiZLRgeaMOVig1mlDqa2YUlhu2wr7a89o+uOkXjpFc5gH6l8Cct4M +pbOfrqkdtx2z/IpZ525yZa31MJQjB/OCFks1mJxTuy/K5FrZx40d/JiZ+yykgmvw +Kh+OC19xXFyuQnspiYHLA6OZyoieC0AJQTPb5lh6/a6ZcMBaD9YThnEvdmn8kN3b +LW7R8pv1GmuebxWMevBLKKAiOIAkbDakO/IwkfN4E8/BPzWr8R0RI7VDIp4BkrcY +AuUR0YLbFQDMYTfBKnya4dC6s1BG7oKsnTH4+yPiAwBIcKMJJnkVU2DzOFytOOqB +AGMUuTNe3QvboEUHGjMJ+E20pwKmafTCWQWIZYVWrkvL4N48fS0ayOn7H6NhStYq +E613TBoYm5EPWNgGVMWX+Ko/IIqmhaZ39qb8HOLubpQzKoNQhArlT4b4UEV4AIHr +W2jjJo3Me1xR9BQsQL4aYB16cmEdH2MtiKrOokWQCPxrvrNQKlr9qEgYRtaQQJKQ +CoReaDH46+0N0x3GfZkYVVYnZS6NRcUk7M7jAgMBAAGjQjBAMA8GA1UdEwEB/wQF +MAMBAf8wHQYDVR0OBBYEFApII6ZgpJIKM+qTW8VX6iVNvRLuMA4GA1UdDwEB/wQE +AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAPpBIqm5iFSVmewzVjIuJndftTgfvnNAU +X15QvWiWkKQUEapobQk1OUAJ2vQJLDSle1mESSmXdMgHHkdt8s4cUCbjnj1AUz/3 +f5Z2EMVGpdAgS1D0NTsY9FVqQRtHBmg8uwkIYtlfVUKqrFOFrJVWNlar5AWMxaja +H6NpvVMPxP/cyuN+8kyIhkdGGvMA9YCRotxDQpSbIPDRzbLrLFPCU3hKTwSUQZqP +JzLB5UkZv/HywouoCjkxKLR9YjYsTewfM7Z+d21+UPCfDtcRj88YxeMn/ibvBZ3P +zzfF0HvaO7AWhAw6k9a+F9sPPg4ZeAnHqQJyIkv3N3a6dcSFA1pj1bF1BcK5vZSt +jBWZp5N99sXzqnTPBIWUmAD04vnKJGW/4GKvyMX6ssmeVkjaef2WdhW+o45WxLM0 +/L5H9MG0qPzVMIho7suuyWPEdr6sOBjhXlzPrjoiUevRi7PzKzMHVIf6tLITe7pT +BGIBnfHAT+7hOtSLIBD6Alfm78ELt5BGnBkpjNxvoEppaZS3JGWg/6w/zgH7IS79 +aPib8qXPMThcFarmlwDB31qlpzmq6YR/PFGoOtmUW4y/Twhx5duoXNTSpv4Ao8YW +xw/ogM4cKGR0GQjTQuPOAF1/sdwTsOEFy9EgqoZ0njnnkf3/W9b3raYvAwtt41dU +63ZTGI0RmLo= +-----END CERTIFICATE----- + +# Issuer: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Subject: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA +# Label: "HARICA TLS ECC Root CA 2021" +# Serial: 137515985548005187474074462014555733966 +# MD5 Fingerprint: ae:f7:4c:e5:66:35:d1:b7:9b:8c:22:93:74:d3:4b:b0 +# SHA1 Fingerprint: bc:b0:c1:9d:e9:98:92:70:19:38:57:e9:8d:a7:b4:5d:6e:ee:01:48 +# SHA256 Fingerprint: 3f:99:cc:47:4a:cf:ce:4d:fe:d5:87:94:66:5e:47:8d:15:47:73:9f:2e:78:0f:1b:b4:ca:9b:13:30:97:d4:01 +-----BEGIN CERTIFICATE----- +MIICVDCCAdugAwIBAgIQZ3SdjXfYO2rbIvT/WeK/zjAKBggqhkjOPQQDAzBsMQsw +CQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2Vh +cmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBFQ0MgUm9v +dCBDQSAyMDIxMB4XDTIxMDIxOTExMDExMFoXDTQ1MDIxMzExMDEwOVowbDELMAkG +A1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj +aCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgRUNDIFJvb3Qg +Q0EgMjAyMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABDgI/rGgltJ6rK9JOtDA4MM7 +KKrxcm1lAEeIhPyaJmuqS7psBAqIXhfyVYf8MLA04jRYVxqEU+kw2anylnTDUR9Y +STHMmE5gEYd103KUkE+bECUqqHgtvpBBWJAVcqeht6NCMEAwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUyRtTgRL+BNUW0aq8mm+3oJUZbsowDgYDVR0PAQH/BAQD +AgGGMAoGCCqGSM49BAMDA2cAMGQCMBHervjcToiwqfAircJRQO9gcS3ujwLEXQNw +SaSS6sUUiHCm0w2wqsosQJz76YJumgIwK0eaB8bRwoF8yguWGEEbo/QwCZ61IygN +nxS2PFOiTAZpffpskcYqSUXm7LcT4Tps +-----END CERTIFICATE----- diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/core.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/core.py new file mode 100644 index 00000000..5d2b8cd3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/certifi/core.py @@ -0,0 +1,60 @@ +# -*- coding: utf-8 -*- + +""" +certifi.py +~~~~~~~~~~ + +This module returns the installation location of cacert.pem or its contents. +""" +import os + +try: + from importlib.resources import path as get_path, read_text + + _CACERT_CTX = None + _CACERT_PATH = None + + def where(): + # This is slightly terrible, but we want to delay extracting the file + # in cases where we're inside of a zipimport situation until someone + # actually calls where(), but we don't want to re-extract the file + # on every call of where(), so we'll do it once then store it in a + # global variable. + global _CACERT_CTX + global _CACERT_PATH + if _CACERT_PATH is None: + # This is slightly janky, the importlib.resources API wants you to + # manage the cleanup of this file, so it doesn't actually return a + # path, it returns a context manager that will give you the path + # when you enter it and will do any cleanup when you leave it. In + # the common case of not needing a temporary file, it will just + # return the file system location and the __exit__() is a no-op. + # + # We also have to hold onto the actual context manager, because + # it will do the cleanup whenever it gets garbage collected, so + # we will also store that at the global level as well. + _CACERT_CTX = get_path("certifi", "cacert.pem") + _CACERT_PATH = str(_CACERT_CTX.__enter__()) + + return _CACERT_PATH + + +except ImportError: + # This fallback will work for Python versions prior to 3.7 that lack the + # importlib.resources module but relies on the existing `where` function + # so won't address issues with environments like PyOxidizer that don't set + # __file__ on modules. + def read_text(_module, _path, encoding="ascii"): + with open(where(), "r", encoding=encoding) as data: + return data.read() + + # If we don't have importlib.resources, then we will just do the old logic + # of assuming we're on the filesystem and munge the path directly. + def where(): + f = os.path.dirname(__file__) + + return os.path.join(f, "cacert.pem") + + +def contents(): + return read_text("certifi", "cacert.pem", encoding="ascii") diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/LICENSE b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/LICENSE new file mode 100644 index 00000000..ad82355b --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2019 TAHRI Ahmed R. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. \ No newline at end of file diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/METADATA new file mode 100644 index 00000000..c062df69 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/METADATA @@ -0,0 +1,267 @@ +Metadata-Version: 2.1 +Name: charset-normalizer +Version: 2.0.7 +Summary: The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet. +Home-page: https://github.com/ousret/charset_normalizer +Author: Ahmed TAHRI @Ousret +Author-email: ahmed.tahri@cloudnursery.dev +License: MIT +Project-URL: Bug Reports, https://github.com/Ousret/charset_normalizer/issues +Project-URL: Documentation, https://charset-normalizer.readthedocs.io/en/latest +Keywords: encoding,i18n,txt,text,charset,charset-detector,normalization,unicode,chardet +Platform: UNKNOWN +Classifier: License :: OSI Approved :: MIT License +Classifier: Intended Audience :: Developers +Classifier: Topic :: Software Development :: Libraries :: Python Modules +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Classifier: Programming Language :: Python :: 3 +Classifier: Programming Language :: Python :: 3.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: 3.9 +Classifier: Programming Language :: Python :: 3.10 +Classifier: Topic :: Text Processing :: Linguistic +Classifier: Topic :: Utilities +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Typing :: Typed +Requires-Python: >=3.5.0 +Description-Content-Type: text/markdown +License-File: LICENSE +Provides-Extra: unicode_backport +Requires-Dist: unicodedata2 ; extra == 'unicode_backport' + + + + +

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

+ +> A library that helps you read text from an unknown charset encoding.
Motivated by `chardet`, +> I'm trying to resolve the issue by taking a new approach. +> All IANA character set names for which the Python core library provides codecs are supported. + +

+ >>>>> 👉 Try Me Online Now, Then Adopt Me 👈 <<<<< +

+ +This project offers you an alternative to **Universal Charset Encoding Detector**, also known as **Chardet**. + +| Feature | [Chardet](https://github.com/chardet/chardet) | Charset Normalizer | [cChardet](https://github.com/PyYoshi/cChardet) | +| ------------- | :-------------: | :------------------: | :------------------: | +| `Fast` | âŒ
| ✅
| ✅
| +| `Universal**` | ⌠| ✅ | ⌠| +| `Reliable` **without** distinguishable standards | ⌠| ✅ | ✅ | +| `Reliable` **with** distinguishable standards | ✅ | ✅ | ✅ | +| `Free & Open` | ✅ | ✅ | ✅ | +| `License` | LGPL-2.1 | MIT | MPL-1.1 +| `Native Python` | ✅ | ✅ | ⌠| +| `Detect spoken language` | ⌠| ✅ | N/A | +| `Supported Encoding` | 30 | :tada: [93](https://charset-normalizer.readthedocs.io/en/latest/support.html) | 40 + +

+Reading Normalized TextCat Reading Text + +*\*\* : They are clearly using specific code for a specific encoding even if covering most of used one*
+ +## ⭠Your support + +*Fork, test-it, star-it, submit your ideas! We do listen.* + +## ⚡ Performance + +This package offer better performance than its counterpart Chardet. Here are some numbers. + +| Package | Accuracy | Mean per file (ms) | File per sec (est) | +| ------------- | :-------------: | :------------------: | :------------------: | +| [chardet](https://github.com/chardet/chardet) | 92 % | 220 ms | 5 file/sec | +| charset-normalizer | **98 %** | **40 ms** | 25 file/sec | + +| Package | 99th percentile | 95th percentile | 50th percentile | +| ------------- | :-------------: | :------------------: | :------------------: | +| [chardet](https://github.com/chardet/chardet) | 1115 ms | 300 ms | 27 ms | +| charset-normalizer | 460 ms | 240 ms | 18 ms | + +Chardet's performance on larger file (1MB+) are very poor. Expect huge difference on large payload. + +> Stats are generated using 400+ files using default parameters. More details on used files, see GHA workflows. +> And yes, these results might change at any time. The dataset can be updated to include more files. +> The actual delays heavily depends on your CPU capabilities. The factors should remain the same. + +[cchardet](https://github.com/PyYoshi/cChardet) is a non-native (cpp binding) faster alternative. If speed is the most important factor, +you should try it. + +## ✨ Installation + +Using PyPi for latest stable +```sh +pip install charset-normalizer -U +``` + +If you want a more up-to-date `unicodedata` than the one available in your Python setup. +```sh +pip install charset-normalizer[unicode_backport] -U +``` + +## 🚀 Basic Usage + +### CLI +This package comes with a CLI. + +``` +usage: normalizer [-h] [-v] [-a] [-n] [-m] [-r] [-f] [-t THRESHOLD] + file [file ...] + +The Real First Universal Charset Detector. Discover originating encoding used +on text file. Normalize text to unicode. + +positional arguments: + files File(s) to be analysed + +optional arguments: + -h, --help show this help message and exit + -v, --verbose Display complementary information about file if any. + Stdout will contain logs about the detection process. + -a, --with-alternative + Output complementary possibilities if any. Top-level + JSON WILL be a list. + -n, --normalize Permit to normalize input file. If not set, program + does not write anything. + -m, --minimal Only output the charset detected to STDOUT. Disabling + JSON output. + -r, --replace Replace file when trying to normalize it instead of + creating a new one. + -f, --force Replace file without asking if you are sure, use this + flag with caution. + -t THRESHOLD, --threshold THRESHOLD + Define a custom maximum amount of chaos allowed in + decoded content. 0. <= chaos <= 1. + --version Show version information and exit. +``` + +```bash +normalizer ./data/sample.1.fr.srt +``` + +:tada: Since version 1.4.0 the CLI produce easily usable stdout result in JSON format. + +```json +{ + "path": "/home/default/projects/charset_normalizer/data/sample.1.fr.srt", + "encoding": "cp1252", + "encoding_aliases": [ + "1252", + "windows_1252" + ], + "alternative_encodings": [ + "cp1254", + "cp1256", + "cp1258", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + "mbcs" + ], + "language": "French", + "alphabets": [ + "Basic Latin", + "Latin-1 Supplement" + ], + "has_sig_or_bom": false, + "chaos": 0.149, + "coherence": 97.152, + "unicode_path": null, + "is_preferred": true +} +``` + +### Python +*Just print out normalized text* +```python +from charset_normalizer import from_path + +results = from_path('./my_subtitle.srt') + +print(str(results.best())) +``` + +*Normalize any text file* +```python +from charset_normalizer import normalize +try: + normalize('./my_subtitle.srt') # should write to disk my_subtitle-***.srt +except IOError as e: + print('Sadly, we are unable to perform charset normalization.', str(e)) +``` + +*Upgrade your code without effort* +```python +from charset_normalizer import detect +``` + +The above code will behave the same as **chardet**. We ensure that we offer the best (reasonable) BC result possible. + +See the docs for advanced usage : [readthedocs.io](https://charset-normalizer.readthedocs.io/en/latest/) + +## 😇 Why + +When I started using Chardet, I noticed that it was not suited to my expectations, and I wanted to propose a +reliable alternative using a completely different method. Also! I never back down on a good challenge! + +I **don't care** about the **originating charset** encoding, because **two different tables** can +produce **two identical rendered string.** +What I want is to get readable text, the best I can. + +In a way, **I'm brute forcing text decoding.** How cool is that ? 😎 + +Don't confuse package **ftfy** with charset-normalizer or chardet. ftfy goal is to repair unicode string whereas charset-normalizer to convert raw file in unknown encoding to unicode. + +## 🰠How + + - Discard all charset encoding table that could not fit the binary content. + - Measure chaos, or the mess once opened (by chunks) with a corresponding charset encoding. + - Extract matches with the lowest mess detected. + - Additionally, we measure coherence / probe for a language. + +**Wait a minute**, what is chaos/mess and coherence according to **YOU ?** + +*Chaos :* I opened hundred of text files, **written by humans**, with the wrong encoding table. **I observed**, then +**I established** some ground rules about **what is obvious** when **it seems like** a mess. + I know that my interpretation of what is chaotic is very subjective, feel free to contribute in order to + improve or rewrite it. + +*Coherence :* For each language there is on earth, we have computed ranked letter appearance occurrences (the best we can). So I thought +that intel is worth something here. So I use those records against decoded text to check if I can detect intelligent design. + +## ⚡ Known limitations + + - Language detection is unreliable when text contains two or more languages sharing identical letters. (eg. HTML (english tags) + Turkish content (Sharing Latin characters)) + - Every charset detector heavily depends on sufficient content. In common cases, do not bother run detection on very tiny content. + +## 👤 Contributing + +Contributions, issues and feature requests are very much welcome.
+Feel free to check [issues page](https://github.com/ousret/charset_normalizer/issues) if you want to contribute. + +## 📠License + +Copyright © 2019 [Ahmed TAHRI @Ousret](https://github.com/Ousret).
+This project is [MIT](https://github.com/Ousret/charset_normalizer/blob/master/LICENSE) licensed. + +Characters frequencies used in this project © 2012 [Denny VrandeÄić](http://simia.net/letters/) + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/RECORD new file mode 100644 index 00000000..57924ce2 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/RECORD @@ -0,0 +1,33 @@ +../../Scripts/normalizer.exe,sha256=qF9NfM9DZIb-mUnGHxguOOhsNhOBvWXWw2ebHkUloio,106372 +charset_normalizer-2.0.7.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +charset_normalizer-2.0.7.dist-info/LICENSE,sha256=6zGgxaT7Cbik4yBV0lweX5w1iidS_vPNcgIT0cz-4kE,1070 +charset_normalizer-2.0.7.dist-info/METADATA,sha256=IBf9rYJsfiUkX_1wIFO3ABSfIPbgA-k1gqrq_VfypyY,11350 +charset_normalizer-2.0.7.dist-info/RECORD,, +charset_normalizer-2.0.7.dist-info/WHEEL,sha256=ewwEueio1C2XeHTvT17n8dZUJgOvyCWCt0WVNLClP9o,92 +charset_normalizer-2.0.7.dist-info/entry_points.txt,sha256=5AJq_EPtGGUwJPgQLnBZfbVr-FYCIwT0xP7dIEZO3NI,77 +charset_normalizer-2.0.7.dist-info/top_level.txt,sha256=7ASyzePr8_xuZWJsnqJjIBtyV8vhEo0wBCv1MPRRi3Q,19 +charset_normalizer/__init__.py,sha256=BVLv4gxL3YZ0xFHfrJacXqdV5YUm98fACgSaEtynXZc,1491 +charset_normalizer/__pycache__/__init__.cpython-39.pyc,, +charset_normalizer/__pycache__/api.cpython-39.pyc,, +charset_normalizer/__pycache__/cd.cpython-39.pyc,, +charset_normalizer/__pycache__/constant.cpython-39.pyc,, +charset_normalizer/__pycache__/legacy.cpython-39.pyc,, +charset_normalizer/__pycache__/md.cpython-39.pyc,, +charset_normalizer/__pycache__/models.cpython-39.pyc,, +charset_normalizer/__pycache__/utils.cpython-39.pyc,, +charset_normalizer/__pycache__/version.cpython-39.pyc,, +charset_normalizer/api.py,sha256=aTYqVTGki22DYJDVqiUyEheBjwo2BKBQNJwa_7SU3KY,17092 +charset_normalizer/assets/__init__.py,sha256=FPnfk8limZRb8ZIUQcTvPEcbuM1eqOdWGw0vbWGycDs,25485 +charset_normalizer/assets/__pycache__/__init__.cpython-39.pyc,, +charset_normalizer/cd.py,sha256=xdMt8glWp1uX84nBJMynjBqr4g951q0jTQ1BX82TJNE,11003 +charset_normalizer/cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +charset_normalizer/cli/__pycache__/__init__.cpython-39.pyc,, +charset_normalizer/cli/__pycache__/normalizer.cpython-39.pyc,, +charset_normalizer/cli/normalizer.py,sha256=H_2C2e81PqNCmUaXuwBJ5Lir_l0wwzELSxjPXcUL9O4,9453 +charset_normalizer/constant.py,sha256=W4u2KeC-RBJP4jxfTK_rOHUERMnejoY21VhIeFOgQKw,19387 +charset_normalizer/legacy.py,sha256=XKeZOts_HdYQU_Jb3C9ZfOjY2CiUL132k9_nXer8gig,3384 +charset_normalizer/md.py,sha256=iCAG4l121wZfZIgJhEDROnAaLcGsvlLNjXMitEBfOZY,17164 +charset_normalizer/models.py,sha256=wObDc9qaxz85xkqh6UozTpL0lLkQuvklO47e81lR89E,13332 +charset_normalizer/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +charset_normalizer/utils.py,sha256=6vfdA59u0VQD3_dDXf2B8viuUWPo9xIfKq4b0nXX6Mo,9026 +charset_normalizer/version.py,sha256=l3uyLlrnBh9G0hbagT5ZkEBPiFCyYfNhUn1Ea_qbRus,79 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/WHEEL new file mode 100644 index 00000000..5bad85fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/entry_points.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/entry_points.txt new file mode 100644 index 00000000..a67f60bc --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/entry_points.txt @@ -0,0 +1,3 @@ +[console_scripts] +normalizer = charset_normalizer.cli.normalizer:cli_detect + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/top_level.txt new file mode 100644 index 00000000..66958f0a --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer-2.0.7.dist-info/top_level.txt @@ -0,0 +1 @@ +charset_normalizer diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__init__.py new file mode 100644 index 00000000..ed525034 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__init__.py @@ -0,0 +1,47 @@ +# -*- coding: utf_8 -*- +""" +Charset-Normalizer +~~~~~~~~~~~~~~ +The Real First Universal Charset Detector. +A library that helps you read text from an unknown charset encoding. +Motivated by chardet, This package is trying to resolve the issue by taking a new approach. +All IANA character set names for which the Python core library provides codecs are supported. + +Basic usage: + >>> from charset_normalizer import from_bytes + >>> results = from_bytes('BÑеки човек има право на образование. Oбразованието!'.encode('utf_8')) + >>> best_guess = results.best() + >>> str(best_guess) + 'BÑеки човек има право на образование. Oбразованието!' + +Others methods and usages are available - see the full documentation +at . +:copyright: (c) 2021 by Ahmed TAHRI +:license: MIT, see LICENSE for more details. +""" +from .api import from_bytes, from_fp, from_path, normalize +from .legacy import ( + CharsetDetector, + CharsetDoctor, + CharsetNormalizerMatch, + CharsetNormalizerMatches, + detect, +) +from .models import CharsetMatch, CharsetMatches +from .version import VERSION, __version__ + +__all__ = ( + "from_fp", + "from_path", + "from_bytes", + "normalize", + "detect", + "CharsetMatch", + "CharsetMatches", + "CharsetNormalizerMatch", + "CharsetNormalizerMatches", + "CharsetDetector", + "CharsetDoctor", + "__version__", + "VERSION", +) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..cdfdab8b76ddf953076882d0ea5eb2c10a9ded67 GIT binary patch literal 1539 zcmcIk&2QsG6nD~mG;Y)F@})g+c%0fuTL+d4L`y_=w}?pF6t#te70FEOX*}wTZOx2R zyaxn(;cwwqkXBR(%D>=>n{S8{|H7Vl&iMm^_82K7+h^E^V>+ZT}xh-M4w%Bkt zN?na_iniMpTkclL*ZCc>?QV;^?p@>??i)e#*y^mO&(|!=ejF01sNNgJQV`CbQE7ks zpU*xCDI8J4;WH+chA$&Fqf#NiaD^vSQ(wo@u?N7}L=u^S4vB`4@18g!pGw-N1R{D4BuQjU{15?h4#UA{P{t*`rV{Y-5D`HYoW>H)L*|EN zs4p@d#)vPL^!8R5X2t?EMXc0UKv1XBB#9-$b!__)QOt)_A;z8!0R4V{e&NL}z3BFp zfeGVQs=Z03sk(8%`=nee_+&-5yYuM!`}{@zYkmpWKjc^W&xV2gGXE{Vfc%f^@A3rzD|7oJimHx$0^^R?(U@e)ca_s)44%2p-Owxlqv&g z0nIVO-CGl-Uov2>7J7qddCypPB?qRAV)!kQ%)_3flA19e)(@^(d*YCiC_aA&< z8g38@?AVjR=SM@k$C*zfMSE~CJh@*2cshK%KRVtodrX*?!lp)u%CY~c;IwyYg>5Ed z-U&ssJf9{-t2`t`hehkQcRKar&SLg%Mz3h!2x2pd#XAdjIn@V5`(bhK^>V6;1_Ht< z?o^A-h0WY!Yn7u4_06yLkB*0jqhiDJ%qGBx^t?`6;x@5l%@DK5ByKoMnuRAf4B0ef z-H?_c4MUoSY#GutF(xn0?={tM0pA;|y$ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/api.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/api.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..619c3355a988be06c07c0d3308b1868210e9ccb8 GIT binary patch literal 9867 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/constant.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/constant.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3042b706f9a37ffc19fce065e05e9f27edc26ad7 GIT binary patch literal 13683 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/legacy.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/legacy.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..b166dbe88646cf65e64d9635e632df975cc04525 GIT binary patch literal 3009 zcmb_eTW=dh6yBL#uh)*9r0Io%kQi=l4Q(hC1XKtLNd!pXpk9Quim=u@V|$yuxHIDf z2ZsmJXMO<>sl-bqegF?V@iXQP@zgh-L8zQF>s)9IVKbWzXNe=`1Qqkb6&}cAJ^Hlsw1bjYf1o_zwcB2}@Ug?| zeCD>pXGC+y4UdD};7zcbVixQZV9)Y7u;;`Huupd6b&UjU1GF1l%pp)O)hXI^D4r%2ci18=9I`hLIkaT3*O3N|PQ0}i&xeLA- zkd#;7c3?fK8yiIaG@-e#8xuIdi97Ll@PiAfuSLJY=IRW-7_!2JW~t~$@t9>o4+?HQ z%R-A-Gd&PYt!x~W*SORwy$mq(dkn@O6o43CB3sUVtSGiRGJ(HL`cAab!GBpVh=*)`a?b^&AZ z16+2UQLaYAVIj2u5M!3;mJN1&kSNw0!OM6u>^fw=%(1vNf+G-!O?(|?Nj}Zv)|)F|4*?vk zS#&K*JfQKgoTnJX!382IBS79S^kw$V#qGAK-pJQ;$gy$yP|EQA@qwv~bg%P{@j5E$ z!<`KF&fElmx<88g!qj2!y@Vr_R@2lImE=lCV42!}7*j!2nc8)Lu_9#w_o+;S@erBx zA)N8L0=9V^RCxkKSb;JulySR7CXxGE6$!-W7$Oe_$&=7?*OAY`&z~Rh%WM5~)KA6Q za16z`acS}0wa=37no6{|FoePbz-kSv8}58(pCaUIWuY$)$Hs?BgXGmqNBh{ zC64wUQ%TE0?YofYP6vy((=qi9IRLBp3vcFMzlRO;Hd5vGzll zT<~4NLGOXs!z6&KIK2&A6ndb;6JhlV=oRi;-3PtO1FKhg4H%yE$@lO8+@676MvrvoEt^MCzNvzM7CtL6%UqSII3cO45 zJPN!NrC_L`<9%ok0(|km4zUDiQ~rc828ibXL zqo`#i0FIv6_3aida7~((ADDSBD~@-FnJayYb=G zfGaDJS)_{s`Ng==Fe%fAmr?HLFbwd4hF3}3hs5~6sUlT!21g+^%hPr`{?V)S(jwB9 s&Mkl1Y)agwLg@nSuKDF$O(FyG|0UB(%E@${>;4h55foJ(f|Me literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/md.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/__pycache__/md.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..0356c26d61b2b01ab6346612fab8173bdc2b1140 GIT binary patch literal 14395 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 CharsetMatches: + """ + Given a raw bytes sequence, return the best possibles charset usable to render str objects. + If there is no results, it is a strong indicator that the source is binary/not text. + By default, the process will extract 5 blocs of 512o each to assess the mess and coherence of a given sequence. + And will give up a particular code page after 20% of measured mess. Those criteria are customizable at will. + + The preemptive behavior DOES NOT replace the traditional detection workflow, it prioritize a particular code page + but never take it for granted. Can improve the performance. + + You may want to focus your attention to some code page or/and not others, use cp_isolation and cp_exclusion for that + purpose. + + This function will strip the SIG in the payload/sequence every time except on UTF-16, UTF-32. + """ + + if not isinstance(sequences, (bytearray, bytes)): + raise TypeError( + "Expected object of type bytes or bytearray, got: {0}".format( + type(sequences) + ) + ) + + if not explain: + logger.setLevel(logging.CRITICAL) + else: + logger.setLevel(logging.INFO) + + length = len(sequences) # type: int + + if length == 0: + logger.warning( + "Given content is empty, stopping the process very early, returning empty utf_8 str match" + ) + return CharsetMatches([CharsetMatch(sequences, "utf_8", 0.0, False, [], "")]) + + if cp_isolation is not None: + logger.warning( + "cp_isolation is set. use this flag for debugging purpose. " + "limited list of encoding allowed : %s.", + ", ".join(cp_isolation), + ) + cp_isolation = [iana_name(cp, False) for cp in cp_isolation] + else: + cp_isolation = [] + + if cp_exclusion is not None: + logger.warning( + "cp_exclusion is set. use this flag for debugging purpose. " + "limited list of encoding excluded : %s.", + ", ".join(cp_exclusion), + ) + cp_exclusion = [iana_name(cp, False) for cp in cp_exclusion] + else: + cp_exclusion = [] + + if length <= (chunk_size * steps): + logger.warning( + "override steps (%i) and chunk_size (%i) as content does not fit (%i byte(s) given) parameters.", + steps, + chunk_size, + length, + ) + steps = 1 + chunk_size = length + + if steps > 1 and length / steps < chunk_size: + chunk_size = int(length / steps) + + is_too_small_sequence = len(sequences) < TOO_SMALL_SEQUENCE # type: bool + is_too_large_sequence = len(sequences) >= TOO_BIG_SEQUENCE # type: bool + + if is_too_small_sequence: + logger.warning( + "Trying to detect encoding from a tiny portion of ({}) byte(s).".format( + length + ) + ) + elif is_too_large_sequence: + logger.info( + "Using lazy str decoding because the payload is quite large, ({}) byte(s).".format( + length + ) + ) + + prioritized_encodings = [] # type: List[str] + + specified_encoding = ( + any_specified_encoding(sequences) if preemptive_behaviour is True else None + ) # type: Optional[str] + + if specified_encoding is not None: + prioritized_encodings.append(specified_encoding) + logger.info( + "Detected declarative mark in sequence. Priority +1 given for %s.", + specified_encoding, + ) + + tested = set() # type: Set[str] + tested_but_hard_failure = [] # type: List[str] + tested_but_soft_failure = [] # type: List[str] + + fallback_ascii = None # type: Optional[CharsetMatch] + fallback_u8 = None # type: Optional[CharsetMatch] + fallback_specified = None # type: Optional[CharsetMatch] + + results = CharsetMatches() # type: CharsetMatches + + sig_encoding, sig_payload = identify_sig_or_bom(sequences) + + if sig_encoding is not None: + prioritized_encodings.append(sig_encoding) + logger.info( + "Detected a SIG or BOM mark on first %i byte(s). Priority +1 given for %s.", + len(sig_payload), + sig_encoding, + ) + + prioritized_encodings.append("ascii") + + if "utf_8" not in prioritized_encodings: + prioritized_encodings.append("utf_8") + + for encoding_iana in prioritized_encodings + IANA_SUPPORTED: + + if cp_isolation and encoding_iana not in cp_isolation: + continue + + if cp_exclusion and encoding_iana in cp_exclusion: + continue + + if encoding_iana in tested: + continue + + tested.add(encoding_iana) + + decoded_payload = None # type: Optional[str] + bom_or_sig_available = sig_encoding == encoding_iana # type: bool + strip_sig_or_bom = bom_or_sig_available and should_strip_sig_or_bom( + encoding_iana + ) # type: bool + + if encoding_iana in {"utf_16", "utf_32"} and bom_or_sig_available is False: + logger.info( + "Encoding %s wont be tested as-is because it require a BOM. Will try some sub-encoder LE/BE.", + encoding_iana, + ) + continue + + try: + is_multi_byte_decoder = is_multi_byte_encoding(encoding_iana) # type: bool + except (ModuleNotFoundError, ImportError): + logger.debug( + "Encoding %s does not provide an IncrementalDecoder", encoding_iana + ) + continue + + try: + if is_too_large_sequence and is_multi_byte_decoder is False: + str( + sequences[: int(50e4)] + if strip_sig_or_bom is False + else sequences[len(sig_payload) : int(50e4)], + encoding=encoding_iana, + ) + else: + decoded_payload = str( + sequences + if strip_sig_or_bom is False + else sequences[len(sig_payload) :], + encoding=encoding_iana, + ) + except (UnicodeDecodeError, LookupError) as e: + if not isinstance(e, LookupError): + logger.warning( + "Code page %s does not fit given bytes sequence at ALL. %s", + encoding_iana, + str(e), + ) + tested_but_hard_failure.append(encoding_iana) + continue + + similar_soft_failure_test = False # type: bool + + for encoding_soft_failed in tested_but_soft_failure: + if is_cp_similar(encoding_iana, encoding_soft_failed): + similar_soft_failure_test = True + break + + if similar_soft_failure_test: + logger.warning( + "%s is deemed too similar to code page %s and was consider unsuited already. Continuing!", + encoding_iana, + encoding_soft_failed, + ) + continue + + r_ = range( + 0 if bom_or_sig_available is False else len(sig_payload), + length, + int(length / steps), + ) + + multi_byte_bonus = ( + is_multi_byte_decoder + and decoded_payload is not None + and len(decoded_payload) < length + ) # type: bool + + if multi_byte_bonus: + logger.info( + "Code page %s is a multi byte encoding table and it appear that at least one character " + "was encoded using n-bytes.", + encoding_iana, + ) + + max_chunk_gave_up = int(len(r_) / 4) # type: int + + if max_chunk_gave_up < 2: + max_chunk_gave_up = 2 + + early_stop_count = 0 # type: int + + md_chunks = [] # type: List[str] + md_ratios = [] + + for i in r_: + cut_sequence = sequences[i : i + chunk_size] + + if bom_or_sig_available and strip_sig_or_bom is False: + cut_sequence = sig_payload + cut_sequence + + chunk = cut_sequence.decode(encoding_iana, errors="ignore") # type: str + + # multi-byte bad cutting detector and adjustment + # not the cleanest way to perform that fix but clever enough for now. + if is_multi_byte_decoder and i > 0 and sequences[i] >= 0x80: + + chunk_partial_size_chk = ( + 16 if chunk_size > 16 else chunk_size + ) # type: int + + if ( + decoded_payload + and chunk[:chunk_partial_size_chk] not in decoded_payload + ): + for j in range(i, i - 4, -1): + cut_sequence = sequences[j : i + chunk_size] + + if bom_or_sig_available and strip_sig_or_bom is False: + cut_sequence = sig_payload + cut_sequence + + chunk = cut_sequence.decode(encoding_iana, errors="ignore") + + if chunk[:chunk_partial_size_chk] in decoded_payload: + break + + md_chunks.append(chunk) + + md_ratios.append(mess_ratio(chunk, threshold)) + + if md_ratios[-1] >= threshold: + early_stop_count += 1 + + if (early_stop_count >= max_chunk_gave_up) or ( + bom_or_sig_available and strip_sig_or_bom is False + ): + break + + if md_ratios: + mean_mess_ratio = sum(md_ratios) / len(md_ratios) # type: float + else: + mean_mess_ratio = 0.0 + + if mean_mess_ratio >= threshold or early_stop_count >= max_chunk_gave_up: + tested_but_soft_failure.append(encoding_iana) + logger.warning( + "%s was excluded because of initial chaos probing. Gave up %i time(s). " + "Computed mean chaos is %f %%.", + encoding_iana, + early_stop_count, + round(mean_mess_ratio * 100, ndigits=3), + ) + # Preparing those fallbacks in case we got nothing. + if encoding_iana in ["ascii", "utf_8", specified_encoding]: + fallback_entry = CharsetMatch( + sequences, encoding_iana, threshold, False, [], decoded_payload + ) + if encoding_iana == specified_encoding: + fallback_specified = fallback_entry + elif encoding_iana == "ascii": + fallback_ascii = fallback_entry + else: + fallback_u8 = fallback_entry + continue + + logger.info( + "%s passed initial chaos probing. Mean measured chaos is %f %%", + encoding_iana, + round(mean_mess_ratio * 100, ndigits=3), + ) + + if not is_multi_byte_decoder: + target_languages = encoding_languages(encoding_iana) # type: List[str] + else: + target_languages = mb_encoding_languages(encoding_iana) + + if target_languages: + logger.info( + "{} should target any language(s) of {}".format( + encoding_iana, str(target_languages) + ) + ) + + cd_ratios = [] + + for chunk in md_chunks: + chunk_languages = coherence_ratio( + chunk, 0.1, ",".join(target_languages) if target_languages else None + ) + + cd_ratios.append(chunk_languages) + + cd_ratios_merged = merge_coherence_ratios(cd_ratios) + + if cd_ratios_merged: + logger.info( + "We detected language {} using {}".format( + cd_ratios_merged, encoding_iana + ) + ) + + results.append( + CharsetMatch( + sequences, + encoding_iana, + mean_mess_ratio, + bom_or_sig_available, + cd_ratios_merged, + decoded_payload, + ) + ) + + if ( + encoding_iana in [specified_encoding, "ascii", "utf_8"] + and mean_mess_ratio < 0.1 + ): + logger.info( + "%s is most likely the one. Stopping the process.", encoding_iana + ) + return CharsetMatches([results[encoding_iana]]) + + if encoding_iana == sig_encoding: + logger.info( + "%s is most likely the one as we detected a BOM or SIG within the beginning of the sequence.", + encoding_iana, + ) + return CharsetMatches([results[encoding_iana]]) + + if len(results) == 0: + if fallback_u8 or fallback_ascii or fallback_specified: + logger.warning( + "Nothing got out of the detection process. Using ASCII/UTF-8/Specified fallback." + ) + + if fallback_specified: + logger.warning( + "%s will be used as a fallback match", fallback_specified.encoding + ) + results.append(fallback_specified) + elif ( + (fallback_u8 and fallback_ascii is None) + or ( + fallback_u8 + and fallback_ascii + and fallback_u8.fingerprint != fallback_ascii.fingerprint + ) + or (fallback_u8 is not None) + ): + logger.warning("utf_8 will be used as a fallback match") + results.append(fallback_u8) + elif fallback_ascii: + logger.warning("ascii will be used as a fallback match") + results.append(fallback_ascii) + + return results + + +def from_fp( + fp: BinaryIO, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, + explain: bool = False, +) -> CharsetMatches: + """ + Same thing than the function from_bytes but using a file pointer that is already ready. + Will not close the file pointer. + """ + return from_bytes( + fp.read(), + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + explain, + ) + + +def from_path( + path: PathLike, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, + explain: bool = False, +) -> CharsetMatches: + """ + Same thing than the function from_bytes but with one extra step. Opening and reading given file path in binary mode. + Can raise IOError. + """ + with open(path, "rb") as fp: + return from_fp( + fp, + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + explain, + ) + + +def normalize( + path: PathLike, + steps: int = 5, + chunk_size: int = 512, + threshold: float = 0.20, + cp_isolation: List[str] = None, + cp_exclusion: List[str] = None, + preemptive_behaviour: bool = True, +) -> CharsetMatch: + """ + Take a (text-based) file path and try to create another file next to it, this time using UTF-8. + """ + results = from_path( + path, + steps, + chunk_size, + threshold, + cp_isolation, + cp_exclusion, + preemptive_behaviour, + ) + + filename = basename(path) + target_extensions = list(splitext(filename)) + + if len(results) == 0: + raise IOError( + 'Unable to normalize "{}", no encoding charset seems to fit.'.format( + filename + ) + ) + + result = results.best() + + target_extensions[0] += "-" + result.encoding # type: ignore + + with open( + "{}".format(str(path).replace(filename, "".join(target_extensions))), "wb" + ) as fp: + fp.write(result.output()) # type: ignore + + return result # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__init__.py new file mode 100644 index 00000000..b2e56ff3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__init__.py @@ -0,0 +1,1244 @@ +# -*- coding: utf_8 -*- +from collections import OrderedDict + +FREQUENCIES = OrderedDict( + [ + ( + "English", + [ + "e", + "a", + "t", + "i", + "o", + "n", + "s", + "r", + "h", + "l", + "d", + "c", + "u", + "m", + "f", + "p", + "g", + "w", + "y", + "b", + "v", + "k", + "x", + "j", + "z", + "q", + ], + ), + ( + "German", + [ + "e", + "n", + "i", + "r", + "s", + "t", + "a", + "d", + "h", + "u", + "l", + "g", + "o", + "c", + "m", + "b", + "f", + "k", + "w", + "z", + "p", + "v", + "ü", + "ä", + "ö", + "j", + ], + ), + ( + "French", + [ + "e", + "a", + "s", + "n", + "i", + "t", + "r", + "l", + "u", + "o", + "d", + "c", + "p", + "m", + "é", + "v", + "g", + "f", + "b", + "h", + "q", + "à", + "x", + "è", + "y", + "j", + ], + ), + ( + "Dutch", + [ + "e", + "n", + "a", + "i", + "r", + "t", + "o", + "d", + "s", + "l", + "g", + "h", + "v", + "m", + "u", + "k", + "c", + "p", + "b", + "w", + "j", + "z", + "f", + "y", + "x", + "ë", + ], + ), + ( + "Italian", + [ + "e", + "i", + "a", + "o", + "n", + "l", + "t", + "r", + "s", + "c", + "d", + "u", + "p", + "m", + "g", + "v", + "f", + "b", + "z", + "h", + "q", + "è", + "à", + "k", + "y", + "ò", + ], + ), + ( + "Polish", + [ + "a", + "i", + "o", + "e", + "n", + "r", + "z", + "w", + "s", + "c", + "t", + "k", + "y", + "d", + "p", + "m", + "u", + "l", + "j", + "Å‚", + "g", + "b", + "h", + "Ä…", + "Ä™", + "ó", + ], + ), + ( + "Spanish", + [ + "e", + "a", + "o", + "n", + "s", + "r", + "i", + "l", + "d", + "t", + "c", + "u", + "m", + "p", + "b", + "g", + "v", + "f", + "y", + "ó", + "h", + "q", + "í", + "j", + "z", + "á", + ], + ), + ( + "Russian", + [ + "о", + "а", + "е", + "и", + "н", + "Ñ", + "Ñ‚", + "Ñ€", + "в", + "л", + "к", + "м", + "д", + "п", + "у", + "г", + "Ñ", + "Ñ‹", + "з", + "б", + "й", + "ÑŒ", + "ч", + "Ñ…", + "ж", + "ц", + ], + ), + ( + "Japanese", + [ + "ã®", + "ã«", + "ã‚‹", + "ãŸ", + "ã¯", + "ー", + "ã¨", + "ã—", + "ã‚’", + "ã§", + "ã¦", + "ãŒ", + "ã„", + "ン", + "ã‚Œ", + "ãª", + "å¹´", + "ス", + "ã£", + "ル", + "ã‹", + "ら", + "ã‚", + "ã•", + "ã‚‚", + "ã‚Š", + ], + ), + ( + "Portuguese", + [ + "a", + "e", + "o", + "s", + "i", + "r", + "d", + "n", + "t", + "m", + "u", + "c", + "l", + "p", + "g", + "v", + "b", + "f", + "h", + "ã", + "q", + "é", + "ç", + "á", + "z", + "í", + ], + ), + ( + "Swedish", + [ + "e", + "a", + "n", + "r", + "t", + "s", + "i", + "l", + "d", + "o", + "m", + "k", + "g", + "v", + "h", + "f", + "u", + "p", + "ä", + "c", + "b", + "ö", + "Ã¥", + "y", + "j", + "x", + ], + ), + ( + "Chinese", + [ + "çš„", + "一", + "是", + "ä¸", + "了", + "在", + "人", + "有", + "我", + "ä»–", + "è¿™", + "个", + "们", + "中", + "æ¥", + "上", + "大", + "为", + "å’Œ", + "国", + "地", + "到", + "以", + "说", + "æ—¶", + "è¦", + "å°±", + "出", + "会", + ], + ), + ( + "Ukrainian", + [ + "о", + "а", + "н", + "Ñ–", + "и", + "Ñ€", + "в", + "Ñ‚", + "е", + "Ñ", + "к", + "л", + "у", + "д", + "м", + "п", + "з", + "Ñ", + "ÑŒ", + "б", + "г", + "й", + "ч", + "Ñ…", + "ц", + "Ñ—", + ], + ), + ( + "Norwegian", + [ + "e", + "r", + "n", + "t", + "a", + "s", + "i", + "o", + "l", + "d", + "g", + "k", + "m", + "v", + "f", + "p", + "u", + "b", + "h", + "Ã¥", + "y", + "j", + "ø", + "c", + "æ", + "w", + ], + ), + ( + "Finnish", + [ + "a", + "i", + "n", + "t", + "e", + "s", + "l", + "o", + "u", + "k", + "ä", + "m", + "r", + "v", + "j", + "h", + "p", + "y", + "d", + "ö", + "g", + "c", + "b", + "f", + "w", + "z", + ], + ), + ( + "Vietnamese", + [ + "n", + "h", + "t", + "i", + "c", + "g", + "a", + "o", + "u", + "m", + "l", + "r", + "à", + "Ä‘", + "s", + "e", + "v", + "p", + "b", + "y", + "Æ°", + "d", + "á", + "k", + "á»™", + "ế", + ], + ), + ( + "Czech", + [ + "o", + "e", + "a", + "n", + "t", + "s", + "i", + "l", + "v", + "r", + "k", + "d", + "u", + "m", + "p", + "í", + "c", + "h", + "z", + "á", + "y", + "j", + "b", + "Ä›", + "é", + "Å™", + ], + ), + ( + "Hungarian", + [ + "e", + "a", + "t", + "l", + "s", + "n", + "k", + "r", + "i", + "o", + "z", + "á", + "é", + "g", + "m", + "b", + "y", + "v", + "d", + "h", + "u", + "p", + "j", + "ö", + "f", + "c", + ], + ), + ( + "Korean", + [ + "ì´", + "다", + "ì—", + "ì˜", + "는", + "ë¡œ", + "하", + "ì„", + "ê°€", + "ê³ ", + "지", + "ì„œ", + "í•œ", + "ì€", + "기", + "으", + "ë…„", + "대", + "사", + "ì‹œ", + "를", + "리", + "ë„", + "ì¸", + "스", + "ì¼", + ], + ), + ( + "Indonesian", + [ + "a", + "n", + "e", + "i", + "r", + "t", + "u", + "s", + "d", + "k", + "m", + "l", + "g", + "p", + "b", + "o", + "h", + "y", + "j", + "c", + "w", + "f", + "v", + "z", + "x", + "q", + ], + ), + ( + "Turkish", + [ + "a", + "e", + "i", + "n", + "r", + "l", + "ı", + "k", + "d", + "t", + "s", + "m", + "y", + "u", + "o", + "b", + "ü", + "ÅŸ", + "v", + "g", + "z", + "h", + "c", + "p", + "ç", + "ÄŸ", + ], + ), + ( + "Romanian", + [ + "e", + "i", + "a", + "r", + "n", + "t", + "u", + "l", + "o", + "c", + "s", + "d", + "p", + "m", + "ă", + "f", + "v", + "î", + "g", + "b", + "È™", + "È›", + "z", + "h", + "â", + "j", + ], + ), + ( + "Farsi", + [ + "ا", + "ÛŒ", + "ر", + "د", + "Ù†", + "Ù‡", + "Ùˆ", + "Ù…", + "ت", + "ب", + "س", + "Ù„", + "Ú©", + "Ø´", + "ز", + "Ù", + "Ú¯", + "ع", + "Ø®", + "Ù‚", + "ج", + "Ø¢", + "Ù¾", + "Ø­", + "Ø·", + "ص", + ], + ), + ( + "Arabic", + [ + "ا", + "Ù„", + "ÙŠ", + "Ù…", + "Ùˆ", + "Ù†", + "ر", + "ت", + "ب", + "Ø©", + "ع", + "د", + "س", + "Ù", + "Ù‡", + "Ùƒ", + "Ù‚", + "Ø£", + "Ø­", + "ج", + "Ø´", + "Ø·", + "ص", + "Ù‰", + "Ø®", + "Ø¥", + ], + ), + ( + "Danish", + [ + "e", + "r", + "n", + "t", + "a", + "i", + "s", + "d", + "l", + "o", + "g", + "m", + "k", + "f", + "v", + "u", + "b", + "h", + "p", + "Ã¥", + "y", + "ø", + "æ", + "c", + "j", + "w", + ], + ), + ( + "Serbian", + [ + "а", + "и", + "о", + "е", + "н", + "Ñ€", + "Ñ", + "у", + "Ñ‚", + "к", + "ј", + "в", + "д", + "м", + "п", + "л", + "г", + "з", + "б", + "a", + "i", + "e", + "o", + "n", + "ц", + "ш", + ], + ), + ( + "Lithuanian", + [ + "i", + "a", + "s", + "o", + "r", + "e", + "t", + "n", + "u", + "k", + "m", + "l", + "p", + "v", + "d", + "j", + "g", + "Ä—", + "b", + "y", + "ų", + "Å¡", + "ž", + "c", + "Ä…", + "į", + ], + ), + ( + "Slovene", + [ + "e", + "a", + "i", + "o", + "n", + "r", + "s", + "l", + "t", + "j", + "v", + "k", + "d", + "p", + "m", + "u", + "z", + "b", + "g", + "h", + "Ä", + "c", + "Å¡", + "ž", + "f", + "y", + ], + ), + ( + "Slovak", + [ + "o", + "a", + "e", + "n", + "i", + "r", + "v", + "t", + "s", + "l", + "k", + "d", + "m", + "p", + "u", + "c", + "h", + "j", + "b", + "z", + "á", + "y", + "ý", + "í", + "Ä", + "é", + ], + ), + ( + "Hebrew", + [ + "×™", + "ו", + "×”", + "ל", + "ר", + "ב", + "ת", + "מ", + "×", + "ש", + "× ", + "×¢", + "×", + "ד", + "ק", + "×—", + "פ", + "ס", + "×›", + "×’", + "ט", + "צ", + "ן", + "×–", + "ך", + ], + ), + ( + "Bulgarian", + [ + "а", + "и", + "о", + "е", + "н", + "Ñ‚", + "Ñ€", + "Ñ", + "в", + "л", + "к", + "д", + "п", + "м", + "з", + "г", + "Ñ", + "ÑŠ", + "у", + "б", + "ч", + "ц", + "й", + "ж", + "щ", + "Ñ…", + ], + ), + ( + "Croatian", + [ + "a", + "i", + "o", + "e", + "n", + "r", + "j", + "s", + "t", + "u", + "k", + "l", + "v", + "d", + "m", + "p", + "g", + "z", + "b", + "c", + "Ä", + "h", + "Å¡", + "ž", + "ć", + "f", + ], + ), + ( + "Hindi", + [ + "क", + "र", + "स", + "न", + "त", + "म", + "ह", + "प", + "य", + "ल", + "व", + "ज", + "द", + "ग", + "ब", + "श", + "ट", + "अ", + "à¤", + "थ", + "भ", + "ड", + "च", + "ध", + "ष", + "इ", + ], + ), + ( + "Estonian", + [ + "a", + "i", + "e", + "s", + "t", + "l", + "u", + "n", + "o", + "k", + "r", + "d", + "m", + "v", + "g", + "p", + "j", + "h", + "ä", + "b", + "õ", + "ü", + "f", + "c", + "ö", + "y", + ], + ), + ( + "Simple English", + [ + "e", + "a", + "t", + "i", + "o", + "n", + "s", + "r", + "h", + "l", + "d", + "c", + "m", + "u", + "f", + "p", + "g", + "w", + "b", + "y", + "v", + "k", + "j", + "x", + "z", + "q", + ], + ), + ( + "Thai", + [ + "า", + "น", + "ร", + "อ", + "à¸", + "เ", + "ง", + "ม", + "ย", + "ล", + "ว", + "ด", + "ท", + "ส", + "ต", + "ะ", + "ป", + "บ", + "ค", + "ห", + "à¹", + "จ", + "พ", + "ช", + "ข", + "ใ", + ], + ), + ( + "Greek", + [ + "α", + "Ï„", + "ο", + "ι", + "ε", + "ν", + "Ï", + "σ", + "κ", + "η", + "Ï€", + "Ï‚", + "Ï…", + "μ", + "λ", + "ί", + "ÏŒ", + "ά", + "γ", + "έ", + "δ", + "ή", + "ω", + "χ", + "θ", + "Ï", + ], + ), + ( + "Tamil", + [ + "க", + "த", + "ப", + "ட", + "à®°", + "à®®", + "ல", + "ன", + "வ", + "à®±", + "ய", + "ள", + "ச", + "ந", + "இ", + "ண", + "à®…", + "ஆ", + "à®´", + "à®™", + "எ", + "உ", + "à®’", + "ஸ", + ], + ), + ( + "Classical Chinese", + [ + "之", + "å¹´", + "為", + "也", + "以", + "一", + "人", + "å…¶", + "者", + "國", + "有", + "二", + "å", + "æ–¼", + "æ›°", + "三", + "ä¸", + "大", + "而", + "å­", + "中", + "五", + "å››", + ], + ), + ( + "Kazakh", + [ + "а", + "Ñ‹", + "е", + "н", + "Ñ‚", + "Ñ€", + "л", + "Ñ–", + "д", + "Ñ", + "м", + "Ò›", + "к", + "о", + "б", + "и", + "у", + "Ò“", + "ж", + "Ò£", + "з", + "ш", + "й", + "п", + "г", + "Ó©", + ], + ), + ] +) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/assets/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..d43da2c35fb3332fd18c3033deaee957357bc33f GIT binary patch literal 7328 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 List[str]: + """ + Return associated unicode ranges in a single byte code page. + """ + if is_multi_byte_encoding(iana_name): + raise IOError("Function not supported on multi-byte code page") + + decoder = importlib.import_module("encodings.{}".format(iana_name)).IncrementalDecoder # type: ignore + + p = decoder(errors="ignore") # type: IncrementalDecoder + seen_ranges = {} # type: Dict[str, int] + character_count = 0 # type: int + + for i in range(0x40, 0xFF): + chunk = p.decode(bytes([i])) # type: str + + if chunk: + character_range = unicode_range(chunk) # type: Optional[str] + + if character_range is None: + continue + + if is_unicode_range_secondary(character_range) is False: + if character_range not in seen_ranges: + seen_ranges[character_range] = 0 + seen_ranges[character_range] += 1 + character_count += 1 + + return sorted( + [ + character_range + for character_range in seen_ranges + if seen_ranges[character_range] / character_count >= 0.15 + ] + ) + + +def unicode_range_languages(primary_range: str) -> List[str]: + """ + Return inferred languages used with a unicode range. + """ + languages = [] # type: List[str] + + for language, characters in FREQUENCIES.items(): + for character in characters: + if unicode_range(character) == primary_range: + languages.append(language) + break + + return languages + + +@lru_cache() +def encoding_languages(iana_name: str) -> List[str]: + """ + Single-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + unicode_ranges = encoding_unicode_range(iana_name) # type: List[str] + primary_range = None # type: Optional[str] + + for specified_range in unicode_ranges: + if "Latin" not in specified_range: + primary_range = specified_range + break + + if primary_range is None: + return ["Latin Based"] + + return unicode_range_languages(primary_range) + + +@lru_cache() +def mb_encoding_languages(iana_name: str) -> List[str]: + """ + Multi-byte encoding language association. Some code page are heavily linked to particular language(s). + This function does the correspondence. + """ + if ( + iana_name.startswith("shift_") + or iana_name.startswith("iso2022_jp") + or iana_name.startswith("euc_j") + or iana_name == "cp932" + ): + return ["Japanese"] + if iana_name.startswith("gb") or iana_name in ZH_NAMES: + return ["Chinese", "Classical Chinese"] + if iana_name.startswith("iso2022_kr") or iana_name in KO_NAMES: + return ["Korean"] + + return [] + + +def alphabet_languages( + characters: List[str], ignore_non_latin: bool = False +) -> List[str]: + """ + Return associated languages associated to given characters. + """ + languages = [] # type: List[Tuple[str, float]] + + source_have_accents = False # type: bool + + for character in characters: + if is_accentuated(character): + source_have_accents = True + break + + for language, language_characters in FREQUENCIES.items(): + + target_have_accents = False # type: bool + target_pure_latin = True # type: bool + + for language_character in language_characters: + if target_have_accents is False and is_accentuated(language_character): + target_have_accents = True + if target_pure_latin is True and is_latin(language_character) is False: + target_pure_latin = False + + if ignore_non_latin and target_pure_latin is False: + continue + + if target_have_accents is False and source_have_accents: + continue + + character_count = len(language_characters) # type: int + + character_match_count = len( + [c for c in language_characters if c in characters] + ) # type: int + + ratio = character_match_count / character_count # type: float + + if ratio >= 0.2: + languages.append((language, ratio)) + + languages = sorted(languages, key=lambda x: x[1], reverse=True) + + return [compatible_language[0] for compatible_language in languages] + + +def characters_popularity_compare( + language: str, ordered_characters: List[str] +) -> float: + """ + Determine if a ordered characters list (by occurrence from most appearance to rarest) match a particular language. + The result is a ratio between 0. (absolutely no correspondence) and 1. (near perfect fit). + Beware that is function is not strict on the match in order to ease the detection. (Meaning close match is 1.) + """ + if language not in FREQUENCIES: + raise ValueError("{} not available".format(language)) + + character_approved_count = 0 # type: int + + for character in ordered_characters: + if character not in FREQUENCIES[language]: + continue + + characters_before_source = FREQUENCIES[language][ + 0 : FREQUENCIES[language].index(character) + ] # type: List[str] + characters_after_source = FREQUENCIES[language][ + FREQUENCIES[language].index(character) : + ] # type: List[str] + + characters_before = ordered_characters[ + 0 : ordered_characters.index(character) + ] # type: List[str] + characters_after = ordered_characters[ + ordered_characters.index(character) : + ] # type: List[str] + + before_match_count = [ + e in characters_before for e in characters_before_source + ].count( + True + ) # type: int + after_match_count = [ + e in characters_after for e in characters_after_source + ].count( + True + ) # type: int + + if len(characters_before_source) == 0 and before_match_count <= 4: + character_approved_count += 1 + continue + + if len(characters_after_source) == 0 and after_match_count <= 4: + character_approved_count += 1 + continue + + if ( + before_match_count / len(characters_before_source) >= 0.4 + or after_match_count / len(characters_after_source) >= 0.4 + ): + character_approved_count += 1 + continue + + return character_approved_count / len(ordered_characters) + + +def alpha_unicode_split(decoded_sequence: str) -> List[str]: + """ + Given a decoded text sequence, return a list of str. Unicode range / alphabet separation. + Ex. a text containing English/Latin with a bit a Hebrew will return two items in the resulting list; + One containing the latin letters and the other hebrew. + """ + layers = OrderedDict() # type: Dict[str, str] + + for character in decoded_sequence: + if character.isalpha() is False: + continue + + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + continue + + layer_target_range = None # type: Optional[str] + + for discovered_range in layers: + if ( + is_suspiciously_successive_range(discovered_range, character_range) + is False + ): + layer_target_range = discovered_range + break + + if layer_target_range is None: + layer_target_range = character_range + + if layer_target_range not in layers: + layers[layer_target_range] = character.lower() + continue + + layers[layer_target_range] += character.lower() + + return list(layers.values()) + + +def merge_coherence_ratios(results: List[CoherenceMatches]) -> CoherenceMatches: + """ + This function merge results previously given by the function coherence_ratio. + The return type is the same as coherence_ratio. + """ + per_language_ratios = OrderedDict() # type: Dict[str, List[float]] + merge = [] # type: CoherenceMatches + + for result in results: + for sub_result in result: + language, ratio = sub_result + if language not in per_language_ratios: + per_language_ratios[language] = [ratio] + continue + per_language_ratios[language].append(ratio) + + for language in per_language_ratios: + merge.append( + ( + language, + round( + sum(per_language_ratios[language]) + / len(per_language_ratios[language]), + 4, + ), + ) + ) + + return sorted(merge, key=lambda x: x[1], reverse=True) + + +@lru_cache(maxsize=2048) +def coherence_ratio( + decoded_sequence: str, threshold: float = 0.1, lg_inclusion: Optional[str] = None +) -> CoherenceMatches: + """ + Detect ANY language that can be identified in given sequence. The sequence will be analysed by layers. + A layer = Character extraction by alphabets/ranges. + """ + + results = [] # type: List[Tuple[str, float]] + lg_inclusion_list = [] # type: List[str] + ignore_non_latin = False # type: bool + + sufficient_match_count = 0 # type: int + + if lg_inclusion is not None: + lg_inclusion_list = lg_inclusion.split(",") + + if "Latin Based" in lg_inclusion_list: + ignore_non_latin = True + lg_inclusion_list.remove("Latin Based") + + for layer in alpha_unicode_split(decoded_sequence): + sequence_frequencies = Counter(layer) # type: Counter + most_common = sequence_frequencies.most_common() + + character_count = sum([o for c, o in most_common]) # type: int + + if character_count <= TOO_SMALL_SEQUENCE: + continue + + popular_character_ordered = [c for c, o in most_common] # type: List[str] + + for language in lg_inclusion_list or alphabet_languages( + popular_character_ordered, ignore_non_latin + ): + ratio = characters_popularity_compare( + language, popular_character_ordered + ) # type: float + + if ratio < threshold: + continue + elif ratio >= 0.8: + sufficient_match_count += 1 + + results.append((language, round(ratio, 4))) + + if sufficient_match_count >= 3: + break + + return sorted(results, key=lambda x: x[1], reverse=True) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e0ffb2ad6540e5908a42f40421dcc7b19b584440 GIT binary patch literal 163 zcmYe~<>g`kf``AV5<&E15P=LBfgA@QE@lA|DGb33nv8xc8Hzx{2;!GVid9T{PHB2h zYD__8S!!OHv7Tj&Pi9g~ab`)XZb4#lc4B&JaZGYXVo`BwNqk;@QEp;RW>spDesWHx getdjpUS>&ryk0@&Ee@O9{FKt1R6CFjpMjVG0N}1E?EnA( literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/__pycache__/normalizer.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f0c9ca64f80ee224449525ede21cf9c6eb8f9f70 GIT binary patch literal 6111 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 Jk47hN{x4H!px*!h literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/normalizer.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/normalizer.py new file mode 100644 index 00000000..f1911259 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/cli/normalizer.py @@ -0,0 +1,291 @@ +import argparse +import sys +from json import dumps +from os.path import abspath +from platform import python_version +from typing import List + +from charset_normalizer import from_fp +from charset_normalizer.models import CliDetectionResult +from charset_normalizer.version import __version__ + + +def query_yes_no(question: str, default: str = "yes") -> bool: + """Ask a yes/no question via input() and return their answer. + + "question" is a string that is presented to the user. + "default" is the presumed answer if the user just hits . + It must be "yes" (the default), "no" or None (meaning + an answer is required of the user). + + The "answer" return value is True for "yes" or False for "no". + + Credit goes to (c) https://stackoverflow.com/questions/3041986/apt-command-line-interface-like-yes-no-input + """ + valid = {"yes": True, "y": True, "ye": True, "no": False, "n": False} + if default is None: + prompt = " [y/n] " + elif default == "yes": + prompt = " [Y/n] " + elif default == "no": + prompt = " [y/N] " + else: + raise ValueError("invalid default answer: '%s'" % default) + + while True: + sys.stdout.write(question + prompt) + choice = input().lower() + if default is not None and choice == "": + return valid[default] + elif choice in valid: + return valid[choice] + else: + sys.stdout.write("Please respond with 'yes' or 'no' " "(or 'y' or 'n').\n") + + +def cli_detect(argv: List[str] = None) -> int: + """ + CLI assistant using ARGV and ArgumentParser + :param argv: + :return: 0 if everything is fine, anything else equal trouble + """ + parser = argparse.ArgumentParser( + description="The Real First Universal Charset Detector. " + "Discover originating encoding used on text file. " + "Normalize text to unicode." + ) + + parser.add_argument( + "files", type=argparse.FileType("rb"), nargs="+", help="File(s) to be analysed" + ) + parser.add_argument( + "-v", + "--verbose", + action="store_true", + default=False, + dest="verbose", + help="Display complementary information about file if any. " + "Stdout will contain logs about the detection process.", + ) + parser.add_argument( + "-a", + "--with-alternative", + action="store_true", + default=False, + dest="alternatives", + help="Output complementary possibilities if any. Top-level JSON WILL be a list.", + ) + parser.add_argument( + "-n", + "--normalize", + action="store_true", + default=False, + dest="normalize", + help="Permit to normalize input file. If not set, program does not write anything.", + ) + parser.add_argument( + "-m", + "--minimal", + action="store_true", + default=False, + dest="minimal", + help="Only output the charset detected to STDOUT. Disabling JSON output.", + ) + parser.add_argument( + "-r", + "--replace", + action="store_true", + default=False, + dest="replace", + help="Replace file when trying to normalize it instead of creating a new one.", + ) + parser.add_argument( + "-f", + "--force", + action="store_true", + default=False, + dest="force", + help="Replace file without asking if you are sure, use this flag with caution.", + ) + parser.add_argument( + "-t", + "--threshold", + action="store", + default=0.1, + type=float, + dest="threshold", + help="Define a custom maximum amount of chaos allowed in decoded content. 0. <= chaos <= 1.", + ) + parser.add_argument( + "--version", + action="version", + version="Charset-Normalizer {} - Python {}".format( + __version__, python_version() + ), + help="Show version information and exit.", + ) + + args = parser.parse_args(argv) + + if args.replace is True and args.normalize is False: + print("Use --replace in addition of --normalize only.", file=sys.stderr) + return 1 + + if args.force is True and args.replace is False: + print("Use --force in addition of --replace only.", file=sys.stderr) + return 1 + + if args.threshold < 0.0 or args.threshold > 1.0: + print("--threshold VALUE should be between 0. AND 1.", file=sys.stderr) + return 1 + + x_ = [] + + for my_file in args.files: + + matches = from_fp(my_file, threshold=args.threshold, explain=args.verbose) + + best_guess = matches.best() + + if best_guess is None: + print( + 'Unable to identify originating encoding for "{}". {}'.format( + my_file.name, + "Maybe try increasing maximum amount of chaos." + if args.threshold < 1.0 + else "", + ), + file=sys.stderr, + ) + x_.append( + CliDetectionResult( + abspath(my_file.name), + None, + [], + [], + "Unknown", + [], + False, + 1.0, + 0.0, + None, + True, + ) + ) + else: + x_.append( + CliDetectionResult( + abspath(my_file.name), + best_guess.encoding, + best_guess.encoding_aliases, + [ + cp + for cp in best_guess.could_be_from_charset + if cp != best_guess.encoding + ], + best_guess.language, + best_guess.alphabets, + best_guess.bom, + best_guess.percent_chaos, + best_guess.percent_coherence, + None, + True, + ) + ) + + if len(matches) > 1 and args.alternatives: + for el in matches: + if el != best_guess: + x_.append( + CliDetectionResult( + abspath(my_file.name), + el.encoding, + el.encoding_aliases, + [ + cp + for cp in el.could_be_from_charset + if cp != el.encoding + ], + el.language, + el.alphabets, + el.bom, + el.percent_chaos, + el.percent_coherence, + None, + False, + ) + ) + + if args.normalize is True: + + if best_guess.encoding.startswith("utf") is True: + print( + '"{}" file does not need to be normalized, as it already came from unicode.'.format( + my_file.name + ), + file=sys.stderr, + ) + if my_file.closed is False: + my_file.close() + continue + + o_ = my_file.name.split(".") # type: List[str] + + if args.replace is False: + o_.insert(-1, best_guess.encoding) + if my_file.closed is False: + my_file.close() + else: + if ( + args.force is False + and query_yes_no( + 'Are you sure to normalize "{}" by replacing it ?'.format( + my_file.name + ), + "no", + ) + is False + ): + if my_file.closed is False: + my_file.close() + continue + + try: + x_[0].unicode_path = abspath("./{}".format(".".join(o_))) + + with open(x_[0].unicode_path, "w", encoding="utf-8") as fp: + fp.write(str(best_guess)) + except IOError as e: + print(str(e), file=sys.stderr) + if my_file.closed is False: + my_file.close() + return 2 + + if my_file.closed is False: + my_file.close() + + if args.minimal is False: + print( + dumps( + [el.__dict__ for el in x_] if len(x_) > 1 else x_[0].__dict__, + ensure_ascii=True, + indent=4, + ) + ) + else: + for my_file in args.files: + print( + ", ".join( + [ + el.encoding if el.encoding else "undefined" + for el in x_ + if el.path == abspath(my_file.name) + ] + ) + ) + + return 0 + + +if __name__ == "__main__": + cli_detect() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/constant.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/constant.py new file mode 100644 index 00000000..2e5974d9 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/constant.py @@ -0,0 +1,496 @@ +from codecs import BOM_UTF8, BOM_UTF16_BE, BOM_UTF16_LE, BOM_UTF32_BE, BOM_UTF32_LE +from collections import OrderedDict +from encodings.aliases import aliases +from re import IGNORECASE, compile as re_compile +from typing import Dict, List, Set, Union + +# Contain for each eligible encoding a list of/item bytes SIG/BOM +ENCODING_MARKS = OrderedDict( + [ + ("utf_8", BOM_UTF8), + ( + "utf_7", + [ + b"\x2b\x2f\x76\x38", + b"\x2b\x2f\x76\x39", + b"\x2b\x2f\x76\x2b", + b"\x2b\x2f\x76\x2f", + b"\x2b\x2f\x76\x38\x2d", + ], + ), + ("gb18030", b"\x84\x31\x95\x33"), + ("utf_32", [BOM_UTF32_BE, BOM_UTF32_LE]), + ("utf_16", [BOM_UTF16_BE, BOM_UTF16_LE]), + ] +) # type: Dict[str, Union[bytes, List[bytes]]] + +TOO_SMALL_SEQUENCE = 32 # type: int +TOO_BIG_SEQUENCE = int(10e6) # type: int + +UTF8_MAXIMAL_ALLOCATION = 1112064 # type: int + +UNICODE_RANGES_COMBINED = { + "Control character": range(0, 31 + 1), + "Basic Latin": range(32, 127 + 1), + "Latin-1 Supplement": range(128, 255 + 1), + "Latin Extended-A": range(256, 383 + 1), + "Latin Extended-B": range(384, 591 + 1), + "IPA Extensions": range(592, 687 + 1), + "Spacing Modifier Letters": range(688, 767 + 1), + "Combining Diacritical Marks": range(768, 879 + 1), + "Greek and Coptic": range(880, 1023 + 1), + "Cyrillic": range(1024, 1279 + 1), + "Cyrillic Supplement": range(1280, 1327 + 1), + "Armenian": range(1328, 1423 + 1), + "Hebrew": range(1424, 1535 + 1), + "Arabic": range(1536, 1791 + 1), + "Syriac": range(1792, 1871 + 1), + "Arabic Supplement": range(1872, 1919 + 1), + "Thaana": range(1920, 1983 + 1), + "NKo": range(1984, 2047 + 1), + "Samaritan": range(2048, 2111 + 1), + "Mandaic": range(2112, 2143 + 1), + "Syriac Supplement": range(2144, 2159 + 1), + "Arabic Extended-A": range(2208, 2303 + 1), + "Devanagari": range(2304, 2431 + 1), + "Bengali": range(2432, 2559 + 1), + "Gurmukhi": range(2560, 2687 + 1), + "Gujarati": range(2688, 2815 + 1), + "Oriya": range(2816, 2943 + 1), + "Tamil": range(2944, 3071 + 1), + "Telugu": range(3072, 3199 + 1), + "Kannada": range(3200, 3327 + 1), + "Malayalam": range(3328, 3455 + 1), + "Sinhala": range(3456, 3583 + 1), + "Thai": range(3584, 3711 + 1), + "Lao": range(3712, 3839 + 1), + "Tibetan": range(3840, 4095 + 1), + "Myanmar": range(4096, 4255 + 1), + "Georgian": range(4256, 4351 + 1), + "Hangul Jamo": range(4352, 4607 + 1), + "Ethiopic": range(4608, 4991 + 1), + "Ethiopic Supplement": range(4992, 5023 + 1), + "Cherokee": range(5024, 5119 + 1), + "Unified Canadian Aboriginal Syllabics": range(5120, 5759 + 1), + "Ogham": range(5760, 5791 + 1), + "Runic": range(5792, 5887 + 1), + "Tagalog": range(5888, 5919 + 1), + "Hanunoo": range(5920, 5951 + 1), + "Buhid": range(5952, 5983 + 1), + "Tagbanwa": range(5984, 6015 + 1), + "Khmer": range(6016, 6143 + 1), + "Mongolian": range(6144, 6319 + 1), + "Unified Canadian Aboriginal Syllabics Extended": range(6320, 6399 + 1), + "Limbu": range(6400, 6479 + 1), + "Tai Le": range(6480, 6527 + 1), + "New Tai Lue": range(6528, 6623 + 1), + "Khmer Symbols": range(6624, 6655 + 1), + "Buginese": range(6656, 6687 + 1), + "Tai Tham": range(6688, 6831 + 1), + "Combining Diacritical Marks Extended": range(6832, 6911 + 1), + "Balinese": range(6912, 7039 + 1), + "Sundanese": range(7040, 7103 + 1), + "Batak": range(7104, 7167 + 1), + "Lepcha": range(7168, 7247 + 1), + "Ol Chiki": range(7248, 7295 + 1), + "Cyrillic Extended C": range(7296, 7311 + 1), + "Sundanese Supplement": range(7360, 7375 + 1), + "Vedic Extensions": range(7376, 7423 + 1), + "Phonetic Extensions": range(7424, 7551 + 1), + "Phonetic Extensions Supplement": range(7552, 7615 + 1), + "Combining Diacritical Marks Supplement": range(7616, 7679 + 1), + "Latin Extended Additional": range(7680, 7935 + 1), + "Greek Extended": range(7936, 8191 + 1), + "General Punctuation": range(8192, 8303 + 1), + "Superscripts and Subscripts": range(8304, 8351 + 1), + "Currency Symbols": range(8352, 8399 + 1), + "Combining Diacritical Marks for Symbols": range(8400, 8447 + 1), + "Letterlike Symbols": range(8448, 8527 + 1), + "Number Forms": range(8528, 8591 + 1), + "Arrows": range(8592, 8703 + 1), + "Mathematical Operators": range(8704, 8959 + 1), + "Miscellaneous Technical": range(8960, 9215 + 1), + "Control Pictures": range(9216, 9279 + 1), + "Optical Character Recognition": range(9280, 9311 + 1), + "Enclosed Alphanumerics": range(9312, 9471 + 1), + "Box Drawing": range(9472, 9599 + 1), + "Block Elements": range(9600, 9631 + 1), + "Geometric Shapes": range(9632, 9727 + 1), + "Miscellaneous Symbols": range(9728, 9983 + 1), + "Dingbats": range(9984, 10175 + 1), + "Miscellaneous Mathematical Symbols-A": range(10176, 10223 + 1), + "Supplemental Arrows-A": range(10224, 10239 + 1), + "Braille Patterns": range(10240, 10495 + 1), + "Supplemental Arrows-B": range(10496, 10623 + 1), + "Miscellaneous Mathematical Symbols-B": range(10624, 10751 + 1), + "Supplemental Mathematical Operators": range(10752, 11007 + 1), + "Miscellaneous Symbols and Arrows": range(11008, 11263 + 1), + "Glagolitic": range(11264, 11359 + 1), + "Latin Extended-C": range(11360, 11391 + 1), + "Coptic": range(11392, 11519 + 1), + "Georgian Supplement": range(11520, 11567 + 1), + "Tifinagh": range(11568, 11647 + 1), + "Ethiopic Extended": range(11648, 11743 + 1), + "Cyrillic Extended-A": range(11744, 11775 + 1), + "Supplemental Punctuation": range(11776, 11903 + 1), + "CJK Radicals Supplement": range(11904, 12031 + 1), + "Kangxi Radicals": range(12032, 12255 + 1), + "Ideographic Description Characters": range(12272, 12287 + 1), + "CJK Symbols and Punctuation": range(12288, 12351 + 1), + "Hiragana": range(12352, 12447 + 1), + "Katakana": range(12448, 12543 + 1), + "Bopomofo": range(12544, 12591 + 1), + "Hangul Compatibility Jamo": range(12592, 12687 + 1), + "Kanbun": range(12688, 12703 + 1), + "Bopomofo Extended": range(12704, 12735 + 1), + "CJK Strokes": range(12736, 12783 + 1), + "Katakana Phonetic Extensions": range(12784, 12799 + 1), + "Enclosed CJK Letters and Months": range(12800, 13055 + 1), + "CJK Compatibility": range(13056, 13311 + 1), + "CJK Unified Ideographs Extension A": range(13312, 19903 + 1), + "Yijing Hexagram Symbols": range(19904, 19967 + 1), + "CJK Unified Ideographs": range(19968, 40959 + 1), + "Yi Syllables": range(40960, 42127 + 1), + "Yi Radicals": range(42128, 42191 + 1), + "Lisu": range(42192, 42239 + 1), + "Vai": range(42240, 42559 + 1), + "Cyrillic Extended-B": range(42560, 42655 + 1), + "Bamum": range(42656, 42751 + 1), + "Modifier Tone Letters": range(42752, 42783 + 1), + "Latin Extended-D": range(42784, 43007 + 1), + "Syloti Nagri": range(43008, 43055 + 1), + "Common Indic Number Forms": range(43056, 43071 + 1), + "Phags-pa": range(43072, 43135 + 1), + "Saurashtra": range(43136, 43231 + 1), + "Devanagari Extended": range(43232, 43263 + 1), + "Kayah Li": range(43264, 43311 + 1), + "Rejang": range(43312, 43359 + 1), + "Hangul Jamo Extended-A": range(43360, 43391 + 1), + "Javanese": range(43392, 43487 + 1), + "Myanmar Extended-B": range(43488, 43519 + 1), + "Cham": range(43520, 43615 + 1), + "Myanmar Extended-A": range(43616, 43647 + 1), + "Tai Viet": range(43648, 43743 + 1), + "Meetei Mayek Extensions": range(43744, 43775 + 1), + "Ethiopic Extended-A": range(43776, 43823 + 1), + "Latin Extended-E": range(43824, 43887 + 1), + "Cherokee Supplement": range(43888, 43967 + 1), + "Meetei Mayek": range(43968, 44031 + 1), + "Hangul Syllables": range(44032, 55215 + 1), + "Hangul Jamo Extended-B": range(55216, 55295 + 1), + "High Surrogates": range(55296, 56191 + 1), + "High Private Use Surrogates": range(56192, 56319 + 1), + "Low Surrogates": range(56320, 57343 + 1), + "Private Use Area": range(57344, 63743 + 1), + "CJK Compatibility Ideographs": range(63744, 64255 + 1), + "Alphabetic Presentation Forms": range(64256, 64335 + 1), + "Arabic Presentation Forms-A": range(64336, 65023 + 1), + "Variation Selectors": range(65024, 65039 + 1), + "Vertical Forms": range(65040, 65055 + 1), + "Combining Half Marks": range(65056, 65071 + 1), + "CJK Compatibility Forms": range(65072, 65103 + 1), + "Small Form Variants": range(65104, 65135 + 1), + "Arabic Presentation Forms-B": range(65136, 65279 + 1), + "Halfwidth and Fullwidth Forms": range(65280, 65519 + 1), + "Specials": range(65520, 65535 + 1), + "Linear B Syllabary": range(65536, 65663 + 1), + "Linear B Ideograms": range(65664, 65791 + 1), + "Aegean Numbers": range(65792, 65855 + 1), + "Ancient Greek Numbers": range(65856, 65935 + 1), + "Ancient Symbols": range(65936, 65999 + 1), + "Phaistos Disc": range(66000, 66047 + 1), + "Lycian": range(66176, 66207 + 1), + "Carian": range(66208, 66271 + 1), + "Coptic Epact Numbers": range(66272, 66303 + 1), + "Old Italic": range(66304, 66351 + 1), + "Gothic": range(66352, 66383 + 1), + "Old Permic": range(66384, 66431 + 1), + "Ugaritic": range(66432, 66463 + 1), + "Old Persian": range(66464, 66527 + 1), + "Deseret": range(66560, 66639 + 1), + "Shavian": range(66640, 66687 + 1), + "Osmanya": range(66688, 66735 + 1), + "Osage": range(66736, 66815 + 1), + "Elbasan": range(66816, 66863 + 1), + "Caucasian Albanian": range(66864, 66927 + 1), + "Linear A": range(67072, 67455 + 1), + "Cypriot Syllabary": range(67584, 67647 + 1), + "Imperial Aramaic": range(67648, 67679 + 1), + "Palmyrene": range(67680, 67711 + 1), + "Nabataean": range(67712, 67759 + 1), + "Hatran": range(67808, 67839 + 1), + "Phoenician": range(67840, 67871 + 1), + "Lydian": range(67872, 67903 + 1), + "Meroitic Hieroglyphs": range(67968, 67999 + 1), + "Meroitic Cursive": range(68000, 68095 + 1), + "Kharoshthi": range(68096, 68191 + 1), + "Old South Arabian": range(68192, 68223 + 1), + "Old North Arabian": range(68224, 68255 + 1), + "Manichaean": range(68288, 68351 + 1), + "Avestan": range(68352, 68415 + 1), + "Inscriptional Parthian": range(68416, 68447 + 1), + "Inscriptional Pahlavi": range(68448, 68479 + 1), + "Psalter Pahlavi": range(68480, 68527 + 1), + "Old Turkic": range(68608, 68687 + 1), + "Old Hungarian": range(68736, 68863 + 1), + "Rumi Numeral Symbols": range(69216, 69247 + 1), + "Brahmi": range(69632, 69759 + 1), + "Kaithi": range(69760, 69839 + 1), + "Sora Sompeng": range(69840, 69887 + 1), + "Chakma": range(69888, 69967 + 1), + "Mahajani": range(69968, 70015 + 1), + "Sharada": range(70016, 70111 + 1), + "Sinhala Archaic Numbers": range(70112, 70143 + 1), + "Khojki": range(70144, 70223 + 1), + "Multani": range(70272, 70319 + 1), + "Khudawadi": range(70320, 70399 + 1), + "Grantha": range(70400, 70527 + 1), + "Newa": range(70656, 70783 + 1), + "Tirhuta": range(70784, 70879 + 1), + "Siddham": range(71040, 71167 + 1), + "Modi": range(71168, 71263 + 1), + "Mongolian Supplement": range(71264, 71295 + 1), + "Takri": range(71296, 71375 + 1), + "Ahom": range(71424, 71487 + 1), + "Warang Citi": range(71840, 71935 + 1), + "Zanabazar Square": range(72192, 72271 + 1), + "Soyombo": range(72272, 72367 + 1), + "Pau Cin Hau": range(72384, 72447 + 1), + "Bhaiksuki": range(72704, 72815 + 1), + "Marchen": range(72816, 72895 + 1), + "Masaram Gondi": range(72960, 73055 + 1), + "Cuneiform": range(73728, 74751 + 1), + "Cuneiform Numbers and Punctuation": range(74752, 74879 + 1), + "Early Dynastic Cuneiform": range(74880, 75087 + 1), + "Egyptian Hieroglyphs": range(77824, 78895 + 1), + "Anatolian Hieroglyphs": range(82944, 83583 + 1), + "Bamum Supplement": range(92160, 92735 + 1), + "Mro": range(92736, 92783 + 1), + "Bassa Vah": range(92880, 92927 + 1), + "Pahawh Hmong": range(92928, 93071 + 1), + "Miao": range(93952, 94111 + 1), + "Ideographic Symbols and Punctuation": range(94176, 94207 + 1), + "Tangut": range(94208, 100351 + 1), + "Tangut Components": range(100352, 101119 + 1), + "Kana Supplement": range(110592, 110847 + 1), + "Kana Extended-A": range(110848, 110895 + 1), + "Nushu": range(110960, 111359 + 1), + "Duployan": range(113664, 113823 + 1), + "Shorthand Format Controls": range(113824, 113839 + 1), + "Byzantine Musical Symbols": range(118784, 119039 + 1), + "Musical Symbols": range(119040, 119295 + 1), + "Ancient Greek Musical Notation": range(119296, 119375 + 1), + "Tai Xuan Jing Symbols": range(119552, 119647 + 1), + "Counting Rod Numerals": range(119648, 119679 + 1), + "Mathematical Alphanumeric Symbols": range(119808, 120831 + 1), + "Sutton SignWriting": range(120832, 121519 + 1), + "Glagolitic Supplement": range(122880, 122927 + 1), + "Mende Kikakui": range(124928, 125151 + 1), + "Adlam": range(125184, 125279 + 1), + "Arabic Mathematical Alphabetic Symbols": range(126464, 126719 + 1), + "Mahjong Tiles": range(126976, 127023 + 1), + "Domino Tiles": range(127024, 127135 + 1), + "Playing Cards": range(127136, 127231 + 1), + "Enclosed Alphanumeric Supplement": range(127232, 127487 + 1), + "Enclosed Ideographic Supplement": range(127488, 127743 + 1), + "Miscellaneous Symbols and Pictographs": range(127744, 128511 + 1), + "Emoticons range(Emoji)": range(128512, 128591 + 1), + "Ornamental Dingbats": range(128592, 128639 + 1), + "Transport and Map Symbols": range(128640, 128767 + 1), + "Alchemical Symbols": range(128768, 128895 + 1), + "Geometric Shapes Extended": range(128896, 129023 + 1), + "Supplemental Arrows-C": range(129024, 129279 + 1), + "Supplemental Symbols and Pictographs": range(129280, 129535 + 1), + "CJK Unified Ideographs Extension B": range(131072, 173791 + 1), + "CJK Unified Ideographs Extension C": range(173824, 177983 + 1), + "CJK Unified Ideographs Extension D": range(177984, 178207 + 1), + "CJK Unified Ideographs Extension E": range(178208, 183983 + 1), + "CJK Unified Ideographs Extension F": range(183984, 191471 + 1), + "CJK Compatibility Ideographs Supplement": range(194560, 195103 + 1), + "Tags": range(917504, 917631 + 1), + "Variation Selectors Supplement": range(917760, 917999 + 1), +} # type: Dict[str, range] + +UNICODE_SECONDARY_RANGE_KEYWORD = [ + "Supplement", + "Extended", + "Extensions", + "Modifier", + "Marks", + "Punctuation", + "Symbols", + "Forms", + "Operators", + "Miscellaneous", + "Drawing", + "Block", + "Shapes", + "Supplemental", + "Tags", +] # type: List[str] + +RE_POSSIBLE_ENCODING_INDICATION = re_compile( + r"(?:(?:encoding)|(?:charset)|(?:coding))(?:[\:= ]{1,10})(?:[\"\']?)([a-zA-Z0-9\-_]+)(?:[\"\']?)", + IGNORECASE, +) + +IANA_SUPPORTED = sorted( + filter( + lambda x: x.endswith("_codec") is False + and x not in {"rot_13", "tactis", "mbcs"}, + list(set(aliases.values())), + ) +) # type: List[str] + +IANA_SUPPORTED_COUNT = len(IANA_SUPPORTED) # type: int + +# pre-computed code page that are similar using the function cp_similarity. +IANA_SUPPORTED_SIMILAR = { + "cp037": ["cp1026", "cp1140", "cp273", "cp500"], + "cp1026": ["cp037", "cp1140", "cp273", "cp500"], + "cp1125": ["cp866"], + "cp1140": ["cp037", "cp1026", "cp273", "cp500"], + "cp1250": ["iso8859_2"], + "cp1251": ["kz1048", "ptcp154"], + "cp1252": ["cp1258", "iso8859_15", "iso8859_9", "latin_1"], + "cp1253": ["iso8859_7"], + "cp1254": ["cp1258", "iso8859_15", "iso8859_9", "latin_1"], + "cp1257": ["iso8859_13"], + "cp1258": ["cp1252", "cp1254", "iso8859_9", "latin_1"], + "cp273": ["cp037", "cp1026", "cp1140", "cp500"], + "cp437": ["cp850", "cp858", "cp860", "cp861", "cp862", "cp863", "cp865"], + "cp500": ["cp037", "cp1026", "cp1140", "cp273"], + "cp850": ["cp437", "cp857", "cp858", "cp865"], + "cp857": ["cp850", "cp858", "cp865"], + "cp858": ["cp437", "cp850", "cp857", "cp865"], + "cp860": ["cp437", "cp861", "cp862", "cp863", "cp865"], + "cp861": ["cp437", "cp860", "cp862", "cp863", "cp865"], + "cp862": ["cp437", "cp860", "cp861", "cp863", "cp865"], + "cp863": ["cp437", "cp860", "cp861", "cp862", "cp865"], + "cp865": ["cp437", "cp850", "cp857", "cp858", "cp860", "cp861", "cp862", "cp863"], + "cp866": ["cp1125"], + "iso8859_10": ["iso8859_14", "iso8859_15", "iso8859_4", "iso8859_9", "latin_1"], + "iso8859_11": ["tis_620"], + "iso8859_13": ["cp1257"], + "iso8859_14": [ + "iso8859_10", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_15": [ + "cp1252", + "cp1254", + "iso8859_10", + "iso8859_14", + "iso8859_16", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_16": [ + "iso8859_14", + "iso8859_15", + "iso8859_2", + "iso8859_3", + "iso8859_9", + "latin_1", + ], + "iso8859_2": ["cp1250", "iso8859_16", "iso8859_4"], + "iso8859_3": ["iso8859_14", "iso8859_15", "iso8859_16", "iso8859_9", "latin_1"], + "iso8859_4": ["iso8859_10", "iso8859_2", "iso8859_9", "latin_1"], + "iso8859_7": ["cp1253"], + "iso8859_9": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "latin_1", + ], + "kz1048": ["cp1251", "ptcp154"], + "latin_1": [ + "cp1252", + "cp1254", + "cp1258", + "iso8859_10", + "iso8859_14", + "iso8859_15", + "iso8859_16", + "iso8859_3", + "iso8859_4", + "iso8859_9", + ], + "mac_iceland": ["mac_roman", "mac_turkish"], + "mac_roman": ["mac_iceland", "mac_turkish"], + "mac_turkish": ["mac_iceland", "mac_roman"], + "ptcp154": ["cp1251", "kz1048"], + "tis_620": ["iso8859_11"], +} # type: Dict[str, List[str]] + + +CHARDET_CORRESPONDENCE = { + "iso2022_kr": "ISO-2022-KR", + "iso2022_jp": "ISO-2022-JP", + "euc_kr": "EUC-KR", + "tis_620": "TIS-620", + "utf_32": "UTF-32", + "euc_jp": "EUC-JP", + "koi8_r": "KOI8-R", + "iso8859_1": "ISO-8859-1", + "iso8859_2": "ISO-8859-2", + "iso8859_5": "ISO-8859-5", + "iso8859_6": "ISO-8859-6", + "iso8859_7": "ISO-8859-7", + "iso8859_8": "ISO-8859-8", + "utf_16": "UTF-16", + "cp855": "IBM855", + "mac_cyrillic": "MacCyrillic", + "gb2312": "GB2312", + "gb18030": "GB18030", + "cp932": "CP932", + "cp866": "IBM866", + "utf_8": "utf-8", + "utf_8_sig": "UTF-8-SIG", + "shift_jis": "SHIFT_JIS", + "big5": "Big5", + "cp1250": "windows-1250", + "cp1251": "windows-1251", + "cp1252": "Windows-1252", + "cp1253": "windows-1253", + "cp1255": "windows-1255", + "cp1256": "windows-1256", + "cp1254": "Windows-1254", + "cp949": "CP949", +} # type: Dict[str, str] + + +COMMON_SAFE_ASCII_CHARACTERS = { + "<", + ">", + "=", + ":", + "/", + "&", + ";", + "{", + "}", + "[", + "]", + ",", + "|", + '"', + "-", +} # type: Set[str] + + +KO_NAMES = {"johab", "cp949", "euc_kr"} # type: Set[str] +ZH_NAMES = {"big5", "cp950", "big5hkscs", "hz"} # type: Set[str] + +NOT_PRINTABLE_PATTERN = re_compile(r"[0-9\W\n\r\t]+") diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/legacy.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/legacy.py new file mode 100644 index 00000000..cdebe2b8 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/legacy.py @@ -0,0 +1,95 @@ +import warnings +from typing import Dict, Optional, Union + +from .api import from_bytes, from_fp, from_path, normalize +from .constant import CHARDET_CORRESPONDENCE +from .models import CharsetMatch, CharsetMatches + + +def detect(byte_str: bytes) -> Dict[str, Optional[Union[str, float]]]: + """ + chardet legacy method + Detect the encoding of the given byte string. It should be mostly backward-compatible. + Encoding name will match Chardet own writing whenever possible. (Not on encoding name unsupported by it) + This function is deprecated and should be used to migrate your project easily, consult the documentation for + further information. Not planned for removal. + + :param byte_str: The byte sequence to examine. + """ + if not isinstance(byte_str, (bytearray, bytes)): + raise TypeError( # pragma: nocover + "Expected object of type bytes or bytearray, got: " + "{0}".format(type(byte_str)) + ) + + if isinstance(byte_str, bytearray): + byte_str = bytes(byte_str) + + r = from_bytes(byte_str).best() + + encoding = r.encoding if r is not None else None + language = r.language if r is not None and r.language != "Unknown" else "" + confidence = 1.0 - r.chaos if r is not None else None + + # Note: CharsetNormalizer does not return 'UTF-8-SIG' as the sig get stripped in the detection/normalization process + # but chardet does return 'utf-8-sig' and it is a valid codec name. + if r is not None and encoding == "utf_8" and r.bom: + encoding += "_sig" + + return { + "encoding": encoding + if encoding not in CHARDET_CORRESPONDENCE + else CHARDET_CORRESPONDENCE[encoding], + "language": language, + "confidence": confidence, + } + + +class CharsetNormalizerMatch(CharsetMatch): + pass + + +class CharsetNormalizerMatches(CharsetMatches): + @staticmethod + def from_fp(*args, **kwargs): # type: ignore + warnings.warn( # pragma: nocover + "staticmethod from_fp, from_bytes, from_path and normalize are deprecated " + "and scheduled to be removed in 3.0", + DeprecationWarning, + ) + return from_fp(*args, **kwargs) # pragma: nocover + + @staticmethod + def from_bytes(*args, **kwargs): # type: ignore + warnings.warn( # pragma: nocover + "staticmethod from_fp, from_bytes, from_path and normalize are deprecated " + "and scheduled to be removed in 3.0", + DeprecationWarning, + ) + return from_bytes(*args, **kwargs) # pragma: nocover + + @staticmethod + def from_path(*args, **kwargs): # type: ignore + warnings.warn( # pragma: nocover + "staticmethod from_fp, from_bytes, from_path and normalize are deprecated " + "and scheduled to be removed in 3.0", + DeprecationWarning, + ) + return from_path(*args, **kwargs) # pragma: nocover + + @staticmethod + def normalize(*args, **kwargs): # type: ignore + warnings.warn( # pragma: nocover + "staticmethod from_fp, from_bytes, from_path and normalize are deprecated " + "and scheduled to be removed in 3.0", + DeprecationWarning, + ) + return normalize(*args, **kwargs) # pragma: nocover + + +class CharsetDetector(CharsetNormalizerMatches): + pass + + +class CharsetDoctor(CharsetNormalizerMatches): + pass diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/md.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/md.py new file mode 100644 index 00000000..2146d61d --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/md.py @@ -0,0 +1,540 @@ +from functools import lru_cache +from typing import List, Optional + +from .constant import COMMON_SAFE_ASCII_CHARACTERS, UNICODE_SECONDARY_RANGE_KEYWORD +from .utils import ( + is_accentuated, + is_ascii, + is_case_variable, + is_cjk, + is_emoticon, + is_hangul, + is_hiragana, + is_katakana, + is_latin, + is_punctuation, + is_separator, + is_symbol, + is_thai, + remove_accent, + unicode_range, +) + + +class MessDetectorPlugin: + """ + Base abstract class used for mess detection plugins. + All detectors MUST extend and implement given methods. + """ + + def eligible(self, character: str) -> bool: + """ + Determine if given character should be fed in. + """ + raise NotImplementedError # pragma: nocover + + def feed(self, character: str) -> None: + """ + The main routine to be executed upon character. + Insert the logic in witch the text would be considered chaotic. + """ + raise NotImplementedError # pragma: nocover + + def reset(self) -> None: + """ + Permit to reset the plugin to the initial state. + """ + raise NotImplementedError # pragma: nocover + + @property + def ratio(self) -> float: + """ + Compute the chaos ratio based on what your feed() has seen. + Must NOT be lower than 0.; No restriction gt 0. + """ + raise NotImplementedError # pragma: nocover + + +class TooManySymbolOrPunctuationPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._punctuation_count = 0 # type: int + self._symbol_count = 0 # type: int + self._character_count = 0 # type: int + + self._last_printable_char = None # type: Optional[str] + self._frenzy_symbol_in_word = False # type: bool + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if ( + character != self._last_printable_char + and character not in COMMON_SAFE_ASCII_CHARACTERS + ): + if is_punctuation(character): + self._punctuation_count += 1 + elif ( + character.isdigit() is False + and is_symbol(character) + and is_emoticon(character) is False + ): + self._symbol_count += 2 + + self._last_printable_char = character + + def reset(self) -> None: + self._punctuation_count = 0 + self._character_count = 0 + self._symbol_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + ratio_of_punctuation = ( + self._punctuation_count + self._symbol_count + ) / self._character_count # type: float + + return ratio_of_punctuation if ratio_of_punctuation >= 0.3 else 0.0 + + +class TooManyAccentuatedPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._character_count = 0 # type: int + self._accentuated_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return character.isalpha() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if is_accentuated(character): + self._accentuated_count += 1 + + def reset(self) -> None: + self._character_count = 0 + self._accentuated_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + ratio_of_accentuation = ( + self._accentuated_count / self._character_count + ) # type: float + return ratio_of_accentuation if ratio_of_accentuation >= 0.35 else 0.0 + + +class UnprintablePlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._unprintable_count = 0 # type: int + self._character_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if ( + character.isspace() is False # includes \n \t \r \v + and character.isprintable() is False + and character != "\x1A" # Why? Its the ASCII substitute character. + ): + self._unprintable_count += 1 + self._character_count += 1 + + def reset(self) -> None: + self._unprintable_count = 0 + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return (self._unprintable_count * 8) / self._character_count + + +class SuspiciousDuplicateAccentPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._successive_count = 0 # type: int + self._character_count = 0 # type: int + + self._last_latin_character = None # type: Optional[str] + + def eligible(self, character: str) -> bool: + return character.isalpha() and is_latin(character) + + def feed(self, character: str) -> None: + self._character_count += 1 + if self._last_latin_character is not None: + if is_accentuated(character) and is_accentuated(self._last_latin_character): + if character.isupper() and self._last_latin_character.isupper(): + self._successive_count += 1 + # Worse if its the same char duplicated with different accent. + if remove_accent(character) == remove_accent( + self._last_latin_character + ): + self._successive_count += 1 + self._last_latin_character = character + + def reset(self) -> None: + self._successive_count = 0 + self._character_count = 0 + self._last_latin_character = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return (self._successive_count * 2) / self._character_count + + +class SuspiciousRange(MessDetectorPlugin): + def __init__(self) -> None: + self._suspicious_successive_range_count = 0 # type: int + self._character_count = 0 # type: int + self._last_printable_seen = None # type: Optional[str] + + def eligible(self, character: str) -> bool: + return character.isprintable() + + def feed(self, character: str) -> None: + self._character_count += 1 + + if ( + character.isspace() + or is_punctuation(character) + or character in COMMON_SAFE_ASCII_CHARACTERS + ): + self._last_printable_seen = None + return + + if self._last_printable_seen is None: + self._last_printable_seen = character + return + + unicode_range_a = unicode_range( + self._last_printable_seen + ) # type: Optional[str] + unicode_range_b = unicode_range(character) # type: Optional[str] + + if is_suspiciously_successive_range(unicode_range_a, unicode_range_b): + self._suspicious_successive_range_count += 1 + + self._last_printable_seen = character + + def reset(self) -> None: + self._character_count = 0 + self._suspicious_successive_range_count = 0 + self._last_printable_seen = None + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + ratio_of_suspicious_range_usage = ( + self._suspicious_successive_range_count * 2 + ) / self._character_count # type: float + + if ratio_of_suspicious_range_usage < 0.1: + return 0.0 + + return ratio_of_suspicious_range_usage + + +class SuperWeirdWordPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._word_count = 0 # type: int + self._bad_word_count = 0 # type: int + self._is_current_word_bad = False # type: bool + self._foreign_long_watch = False # type: bool + + self._character_count = 0 # type: int + self._bad_character_count = 0 # type: int + + self._buffer = "" # type: str + self._buffer_accent_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character.isalpha(): + self._buffer = "".join([self._buffer, character]) + if is_accentuated(character): + self._buffer_accent_count += 1 + if ( + self._foreign_long_watch is False + and is_latin(character) is False + and is_cjk(character) is False + and is_hangul(character) is False + and is_katakana(character) is False + and is_hiragana(character) is False + and is_thai(character) is False + ): + self._foreign_long_watch = True + return + if not self._buffer: + return + if ( + character.isspace() or is_punctuation(character) or is_separator(character) + ) and self._buffer: + self._word_count += 1 + buffer_length = len(self._buffer) # type: int + + self._character_count += buffer_length + + if buffer_length >= 4 and self._buffer_accent_count / buffer_length > 0.34: + self._is_current_word_bad = True + if buffer_length >= 24 and self._foreign_long_watch: + self._is_current_word_bad = True + + if self._is_current_word_bad: + self._bad_word_count += 1 + self._bad_character_count += len(self._buffer) + self._is_current_word_bad = False + + self._foreign_long_watch = False + self._buffer = "" + self._buffer_accent_count = 0 + elif ( + character not in {"<", ">", "-", "="} + and character.isdigit() is False + and is_symbol(character) + ): + self._is_current_word_bad = True + self._buffer += character + + def reset(self) -> None: + self._buffer = "" + self._is_current_word_bad = False + self._foreign_long_watch = False + self._bad_word_count = 0 + self._word_count = 0 + self._character_count = 0 + self._bad_character_count = 0 + + @property + def ratio(self) -> float: + if self._word_count <= 10: + return 0.0 + + return self._bad_character_count / self._character_count + + +class CjkInvalidStopPlugin(MessDetectorPlugin): + """ + GB(Chinese) based encoding often render the stop incorrectly when the content does not fit and + can be easily detected. Searching for the overuse of '丅' and '丄'. + """ + + def __init__(self) -> None: + self._wrong_stop_count = 0 # type: int + self._cjk_character_count = 0 # type: int + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + if character in ["丅", "丄"]: + self._wrong_stop_count += 1 + return + if is_cjk(character): + self._cjk_character_count += 1 + + def reset(self) -> None: + self._wrong_stop_count = 0 + self._cjk_character_count = 0 + + @property + def ratio(self) -> float: + if self._cjk_character_count < 16: + return 0.0 + return self._wrong_stop_count / self._cjk_character_count + + +class ArchaicUpperLowerPlugin(MessDetectorPlugin): + def __init__(self) -> None: + self._buf = False # type: bool + + self._character_count_since_last_sep = 0 # type: int + + self._successive_upper_lower_count = 0 # type: int + self._successive_upper_lower_count_final = 0 # type: int + + self._character_count = 0 # type: int + + self._last_alpha_seen = None # type: Optional[str] + self._current_ascii_only = True # type: bool + + def eligible(self, character: str) -> bool: + return True + + def feed(self, character: str) -> None: + is_concerned = character.isalpha() and is_case_variable(character) + chunk_sep = is_concerned is False + + if chunk_sep and self._character_count_since_last_sep > 0: + if ( + self._character_count_since_last_sep <= 64 + and character.isdigit() is False + and self._current_ascii_only is False + ): + self._successive_upper_lower_count_final += ( + self._successive_upper_lower_count + ) + + self._successive_upper_lower_count = 0 + self._character_count_since_last_sep = 0 + self._last_alpha_seen = None + self._buf = False + self._character_count += 1 + self._current_ascii_only = True + + return + + if self._current_ascii_only is True and is_ascii(character) is False: + self._current_ascii_only = False + + if self._last_alpha_seen is not None: + if (character.isupper() and self._last_alpha_seen.islower()) or ( + character.islower() and self._last_alpha_seen.isupper() + ): + if self._buf is True: + self._successive_upper_lower_count += 2 + self._buf = False + else: + self._buf = True + else: + self._buf = False + + self._character_count += 1 + self._character_count_since_last_sep += 1 + self._last_alpha_seen = character + + def reset(self) -> None: + self._character_count = 0 + self._character_count_since_last_sep = 0 + self._successive_upper_lower_count = 0 + self._successive_upper_lower_count_final = 0 + self._last_alpha_seen = None + self._buf = False + self._current_ascii_only = True + + @property + def ratio(self) -> float: + if self._character_count == 0: + return 0.0 + + return self._successive_upper_lower_count_final / self._character_count + + +def is_suspiciously_successive_range( + unicode_range_a: Optional[str], unicode_range_b: Optional[str] +) -> bool: + """ + Determine if two Unicode range seen next to each other can be considered as suspicious. + """ + if unicode_range_a is None or unicode_range_b is None: + return True + + if unicode_range_a == unicode_range_b: + return False + + if "Latin" in unicode_range_a and "Latin" in unicode_range_b: + return False + + if "Emoticons" in unicode_range_a or "Emoticons" in unicode_range_b: + return False + + keywords_range_a, keywords_range_b = unicode_range_a.split( + " " + ), unicode_range_b.split(" ") + + for el in keywords_range_a: + if el in UNICODE_SECONDARY_RANGE_KEYWORD: + continue + if el in keywords_range_b: + return False + + # Japanese Exception + range_a_jp_chars, range_b_jp_chars = ( + unicode_range_a + in ( + "Hiragana", + "Katakana", + ), + unicode_range_b in ("Hiragana", "Katakana"), + ) + if range_a_jp_chars or range_b_jp_chars: + if "CJK" in unicode_range_a or "CJK" in unicode_range_b: + return False + if range_a_jp_chars and range_b_jp_chars: + return False + + if "Hangul" in unicode_range_a or "Hangul" in unicode_range_b: + if "CJK" in unicode_range_a or "CJK" in unicode_range_b: + return False + if unicode_range_a == "Basic Latin" or unicode_range_b == "Basic Latin": + return False + + # Chinese/Japanese use dedicated range for punctuation and/or separators. + if ("CJK" in unicode_range_a or "CJK" in unicode_range_b) or ( + unicode_range_a in ["Katakana", "Hiragana"] + and unicode_range_b in ["Katakana", "Hiragana"] + ): + if "Punctuation" in unicode_range_a or "Punctuation" in unicode_range_b: + return False + if "Forms" in unicode_range_a or "Forms" in unicode_range_b: + return False + + return True + + +@lru_cache(maxsize=2048) +def mess_ratio( + decoded_sequence: str, maximum_threshold: float = 0.2, debug: bool = False +) -> float: + """ + Compute a mess ratio given a decoded bytes sequence. The maximum threshold does stop the computation earlier. + """ + + detectors = [ + md_class() for md_class in MessDetectorPlugin.__subclasses__() + ] # type: List[MessDetectorPlugin] + + length = len(decoded_sequence) # type: int + + mean_mess_ratio = 0.0 # type: float + + if length < 512: + intermediary_mean_mess_ratio_calc = 32 # type: int + elif length <= 1024: + intermediary_mean_mess_ratio_calc = 64 + else: + intermediary_mean_mess_ratio_calc = 128 + + for character, index in zip(decoded_sequence, range(0, length)): + for detector in detectors: + if detector.eligible(character): + detector.feed(character) + + if ( + index > 0 and index % intermediary_mean_mess_ratio_calc == 0 + ) or index == length - 1: + mean_mess_ratio = sum([dt.ratio for dt in detectors]) + + if mean_mess_ratio >= maximum_threshold: + break + + if debug: + for dt in detectors: # pragma: nocover + print(dt.__class__, dt.ratio) + + return round(mean_mess_ratio, 3) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/models.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/models.py new file mode 100644 index 00000000..68c27b89 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/models.py @@ -0,0 +1,393 @@ +import warnings +from collections import Counter +from encodings.aliases import aliases +from hashlib import sha256 +from json import dumps +from re import sub +from typing import Any, Dict, Iterator, List, Optional, Tuple, Union + +from .constant import NOT_PRINTABLE_PATTERN, TOO_BIG_SEQUENCE +from .md import mess_ratio +from .utils import iana_name, is_multi_byte_encoding, unicode_range + + +class CharsetMatch: + def __init__( + self, + payload: bytes, + guessed_encoding: str, + mean_mess_ratio: float, + has_sig_or_bom: bool, + languages: "CoherenceMatches", + decoded_payload: Optional[str] = None, + ): + self._payload = payload # type: bytes + + self._encoding = guessed_encoding # type: str + self._mean_mess_ratio = mean_mess_ratio # type: float + self._languages = languages # type: CoherenceMatches + self._has_sig_or_bom = has_sig_or_bom # type: bool + self._unicode_ranges = None # type: Optional[List[str]] + + self._leaves = [] # type: List[CharsetMatch] + self._mean_coherence_ratio = 0.0 # type: float + + self._output_payload = None # type: Optional[bytes] + self._output_encoding = None # type: Optional[str] + + self._string = decoded_payload # type: Optional[str] + + def __eq__(self, other: object) -> bool: + if not isinstance(other, CharsetMatch): + raise TypeError( + "__eq__ cannot be invoked on {} and {}.".format( + str(other.__class__), str(self.__class__) + ) + ) + return self.encoding == other.encoding and self.fingerprint == other.fingerprint + + def __lt__(self, other: object) -> bool: + """ + Implemented to make sorted available upon CharsetMatches items. + """ + if not isinstance(other, CharsetMatch): + raise ValueError + + chaos_difference = abs(self.chaos - other.chaos) # type: float + coherence_difference = abs(self.coherence - other.coherence) # type: float + + # Bellow 1% difference --> Use Coherence + if chaos_difference < 0.01 and coherence_difference > 0.02: + # When having a tough decision, use the result that decoded as many multi-byte as possible. + if chaos_difference == 0.0 and self.coherence == other.coherence: + return self.multi_byte_usage > other.multi_byte_usage + return self.coherence > other.coherence + + return self.chaos < other.chaos + + @property + def multi_byte_usage(self) -> float: + return 1.0 - len(str(self)) / len(self.raw) + + @property + def chaos_secondary_pass(self) -> float: + """ + Check once again chaos in decoded text, except this time, with full content. + Use with caution, this can be very slow. + Notice: Will be removed in 3.0 + """ + warnings.warn( + "chaos_secondary_pass is deprecated and will be removed in 3.0", + DeprecationWarning, + ) + return mess_ratio(str(self), 1.0) + + @property + def coherence_non_latin(self) -> float: + """ + Coherence ratio on the first non-latin language detected if ANY. + Notice: Will be removed in 3.0 + """ + warnings.warn( + "coherence_non_latin is deprecated and will be removed in 3.0", + DeprecationWarning, + ) + return 0.0 + + @property + def w_counter(self) -> Counter: + """ + Word counter instance on decoded text. + Notice: Will be removed in 3.0 + """ + warnings.warn( + "w_counter is deprecated and will be removed in 3.0", DeprecationWarning + ) + + string_printable_only = sub(NOT_PRINTABLE_PATTERN, " ", str(self).lower()) + + return Counter(string_printable_only.split()) + + def __str__(self) -> str: + # Lazy Str Loading + if self._string is None: + self._string = str(self._payload, self._encoding, "strict") + return self._string + + def __repr__(self) -> str: + return "".format(self.encoding, self.fingerprint) + + def add_submatch(self, other: "CharsetMatch") -> None: + if not isinstance(other, CharsetMatch) or other == self: + raise ValueError( + "Unable to add instance <{}> as a submatch of a CharsetMatch".format( + other.__class__ + ) + ) + + other._string = None # Unload RAM usage; dirty trick. + self._leaves.append(other) + + @property + def encoding(self) -> str: + return self._encoding + + @property + def encoding_aliases(self) -> List[str]: + """ + Encoding name are known by many name, using this could help when searching for IBM855 when it's listed as CP855. + """ + also_known_as = [] # type: List[str] + for u, p in aliases.items(): + if self.encoding == u: + also_known_as.append(p) + elif self.encoding == p: + also_known_as.append(u) + return also_known_as + + @property + def bom(self) -> bool: + return self._has_sig_or_bom + + @property + def byte_order_mark(self) -> bool: + return self._has_sig_or_bom + + @property + def languages(self) -> List[str]: + """ + Return the complete list of possible languages found in decoded sequence. + Usually not really useful. Returned list may be empty even if 'language' property return something != 'Unknown'. + """ + return [e[0] for e in self._languages] + + @property + def language(self) -> str: + """ + Most probable language found in decoded sequence. If none were detected or inferred, the property will return + "Unknown". + """ + if not self._languages: + # Trying to infer the language based on the given encoding + # Its either English or we should not pronounce ourselves in certain cases. + if "ascii" in self.could_be_from_charset: + return "English" + + # doing it there to avoid circular import + from charset_normalizer.cd import encoding_languages, mb_encoding_languages + + languages = ( + mb_encoding_languages(self.encoding) + if is_multi_byte_encoding(self.encoding) + else encoding_languages(self.encoding) + ) + + if len(languages) == 0 or "Latin Based" in languages: + return "Unknown" + + return languages[0] + + return self._languages[0][0] + + @property + def chaos(self) -> float: + return self._mean_mess_ratio + + @property + def coherence(self) -> float: + if not self._languages: + return 0.0 + return self._languages[0][1] + + @property + def percent_chaos(self) -> float: + return round(self.chaos * 100, ndigits=3) + + @property + def percent_coherence(self) -> float: + return round(self.coherence * 100, ndigits=3) + + @property + def raw(self) -> bytes: + """ + Original untouched bytes. + """ + return self._payload + + @property + def submatch(self) -> List["CharsetMatch"]: + return self._leaves + + @property + def has_submatch(self) -> bool: + return len(self._leaves) > 0 + + @property + def alphabets(self) -> List[str]: + if self._unicode_ranges is not None: + return self._unicode_ranges + # list detected ranges + detected_ranges = [ + unicode_range(char) for char in str(self) + ] # type: List[Optional[str]] + # filter and sort + self._unicode_ranges = sorted(list({r for r in detected_ranges if r})) + return self._unicode_ranges + + @property + def could_be_from_charset(self) -> List[str]: + """ + The complete list of encoding that output the exact SAME str result and therefore could be the originating + encoding. + This list does include the encoding available in property 'encoding'. + """ + return [self._encoding] + [m.encoding for m in self._leaves] + + def first(self) -> "CharsetMatch": + """ + Kept for BC reasons. Will be removed in 3.0. + """ + return self + + def best(self) -> "CharsetMatch": + """ + Kept for BC reasons. Will be removed in 3.0. + """ + return self + + def output(self, encoding: str = "utf_8") -> bytes: + """ + Method to get re-encoded bytes payload using given target encoding. Default to UTF-8. + Any errors will be simply ignored by the encoder NOT replaced. + """ + if self._output_encoding is None or self._output_encoding != encoding: + self._output_encoding = encoding + self._output_payload = str(self).encode(encoding, "replace") + + return self._output_payload # type: ignore + + @property + def fingerprint(self) -> str: + """ + Retrieve the unique SHA256 computed using the transformed (re-encoded) payload. Not the original one. + """ + return sha256(self.output()).hexdigest() + + +class CharsetMatches: + """ + Container with every CharsetMatch items ordered by default from most probable to the less one. + Act like a list(iterable) but does not implements all related methods. + """ + + def __init__(self, results: List[CharsetMatch] = None): + self._results = sorted(results) if results else [] # type: List[CharsetMatch] + + def __iter__(self) -> Iterator[CharsetMatch]: + for result in self._results: + yield result + + def __getitem__(self, item: Union[int, str]) -> CharsetMatch: + """ + Retrieve a single item either by its position or encoding name (alias may be used here). + Raise KeyError upon invalid index or encoding not present in results. + """ + if isinstance(item, int): + return self._results[item] + if isinstance(item, str): + item = iana_name(item, False) + for result in self._results: + if item in result.could_be_from_charset: + return result + raise KeyError + + def __len__(self) -> int: + return len(self._results) + + def __bool__(self) -> bool: + return len(self._results) > 0 + + def append(self, item: CharsetMatch) -> None: + """ + Insert a single match. Will be inserted accordingly to preserve sort. + Can be inserted as a submatch. + """ + if not isinstance(item, CharsetMatch): + raise ValueError( + "Cannot append instance '{}' to CharsetMatches".format( + str(item.__class__) + ) + ) + # We should disable the submatch factoring when the input file is too heavy (conserve RAM usage) + if len(item.raw) <= TOO_BIG_SEQUENCE: + for match in self._results: + if match.fingerprint == item.fingerprint and match.chaos == item.chaos: + match.add_submatch(item) + return + self._results.append(item) + self._results = sorted(self._results) + + def best(self) -> Optional["CharsetMatch"]: + """ + Simply return the first match. Strict equivalent to matches[0]. + """ + if not self._results: + return None + return self._results[0] + + def first(self) -> Optional["CharsetMatch"]: + """ + Redundant method, call the method best(). Kept for BC reasons. + """ + return self.best() + + +CoherenceMatch = Tuple[str, float] +CoherenceMatches = List[CoherenceMatch] + + +class CliDetectionResult: + def __init__( + self, + path: str, + encoding: Optional[str], + encoding_aliases: List[str], + alternative_encodings: List[str], + language: str, + alphabets: List[str], + has_sig_or_bom: bool, + chaos: float, + coherence: float, + unicode_path: Optional[str], + is_preferred: bool, + ): + self.path = path # type: str + self.unicode_path = unicode_path # type: Optional[str] + self.encoding = encoding # type: Optional[str] + self.encoding_aliases = encoding_aliases # type: List[str] + self.alternative_encodings = alternative_encodings # type: List[str] + self.language = language # type: str + self.alphabets = alphabets # type: List[str] + self.has_sig_or_bom = has_sig_or_bom # type: bool + self.chaos = chaos # type: float + self.coherence = coherence # type: float + self.is_preferred = is_preferred # type: bool + + @property + def __dict__(self) -> Dict[str, Any]: # type: ignore + return { + "path": self.path, + "encoding": self.encoding, + "encoding_aliases": self.encoding_aliases, + "alternative_encodings": self.alternative_encodings, + "language": self.language, + "alphabets": self.alphabets, + "has_sig_or_bom": self.has_sig_or_bom, + "chaos": self.chaos, + "coherence": self.coherence, + "unicode_path": self.unicode_path, + "is_preferred": self.is_preferred, + } + + def to_json(self) -> str: + return dumps(self.__dict__, ensure_ascii=True, indent=4) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/py.typed b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/py.typed new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/utils.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/utils.py new file mode 100644 index 00000000..b9d12784 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/utils.py @@ -0,0 +1,333 @@ +try: + import unicodedata2 as unicodedata +except ImportError: + import unicodedata # type: ignore[no-redef] + +import importlib +from codecs import IncrementalDecoder +from encodings.aliases import aliases +from functools import lru_cache +from re import findall +from typing import List, Optional, Set, Tuple, Union + +from _multibytecodec import MultibyteIncrementalDecoder # type: ignore + +from .constant import ( + ENCODING_MARKS, + IANA_SUPPORTED_SIMILAR, + RE_POSSIBLE_ENCODING_INDICATION, + UNICODE_RANGES_COMBINED, + UNICODE_SECONDARY_RANGE_KEYWORD, + UTF8_MAXIMAL_ALLOCATION, +) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_accentuated(character: str) -> bool: + try: + description = unicodedata.name(character) # type: str + except ValueError: + return False + return ( + "WITH GRAVE" in description + or "WITH ACUTE" in description + or "WITH CEDILLA" in description + or "WITH DIAERESIS" in description + or "WITH CIRCUMFLEX" in description + or "WITH TILDE" in description + ) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def remove_accent(character: str) -> str: + decomposed = unicodedata.decomposition(character) # type: str + if not decomposed: + return character + + codes = decomposed.split(" ") # type: List[str] + + return chr(int(codes[0], 16)) + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def unicode_range(character: str) -> Optional[str]: + """ + Retrieve the Unicode range official name from a single character. + """ + character_ord = ord(character) # type: int + + for range_name, ord_range in UNICODE_RANGES_COMBINED.items(): + if character_ord in ord_range: + return range_name + + return None + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_latin(character: str) -> bool: + try: + description = unicodedata.name(character) # type: str + except ValueError: + return False + return "LATIN" in description + + +def is_ascii(character: str) -> bool: + try: + character.encode("ascii") + except UnicodeEncodeError: + return False + return True + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_punctuation(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + if "P" in character_category: + return True + + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + return False + + return "Punctuation" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_symbol(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + if "S" in character_category or "N" in character_category: + return True + + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + return False + + return "Forms" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_emoticon(character: str) -> bool: + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + return False + + return "Emoticons" in character_range + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_separator(character: str) -> bool: + if character.isspace() or character in ["|", "+", ",", ";", "<", ">"]: + return True + + character_category = unicodedata.category(character) # type: str + + return "Z" in character_category + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_case_variable(character: str) -> bool: + return character.islower() != character.isupper() + + +def is_private_use_only(character: str) -> bool: + character_category = unicodedata.category(character) # type: str + + return "Co" == character_category + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_cjk(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "CJK" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_hiragana(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "HIRAGANA" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_katakana(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "KATAKANA" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_hangul(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "HANGUL" in character_name + + +@lru_cache(maxsize=UTF8_MAXIMAL_ALLOCATION) +def is_thai(character: str) -> bool: + try: + character_name = unicodedata.name(character) + except ValueError: + return False + + return "THAI" in character_name + + +@lru_cache(maxsize=len(UNICODE_RANGES_COMBINED)) +def is_unicode_range_secondary(range_name: str) -> bool: + for keyword in UNICODE_SECONDARY_RANGE_KEYWORD: + if keyword in range_name: + return True + + return False + + +def any_specified_encoding(sequence: bytes, search_zone: int = 4096) -> Optional[str]: + """ + Extract using ASCII-only decoder any specified encoding in the first n-bytes. + """ + if not isinstance(sequence, bytes): + raise TypeError + + seq_len = len(sequence) # type: int + + results = findall( + RE_POSSIBLE_ENCODING_INDICATION, + sequence[: seq_len if seq_len <= search_zone else search_zone].decode( + "ascii", errors="ignore" + ), + ) # type: List[str] + + if len(results) == 0: + return None + + for specified_encoding in results: + specified_encoding = specified_encoding.lower().replace("-", "_") + + for encoding_alias, encoding_iana in aliases.items(): + if encoding_alias == specified_encoding: + return encoding_iana + if encoding_iana == specified_encoding: + return encoding_iana + + return None + + +@lru_cache(maxsize=128) +def is_multi_byte_encoding(name: str) -> bool: + """ + Verify is a specific encoding is a multi byte one based on it IANA name + """ + return name in { + "utf_8", + "utf_8_sig", + "utf_16", + "utf_16_be", + "utf_16_le", + "utf_32", + "utf_32_le", + "utf_32_be", + "utf_7", + } or issubclass( + importlib.import_module("encodings.{}".format(name)).IncrementalDecoder, # type: ignore + MultibyteIncrementalDecoder, + ) + + +def identify_sig_or_bom(sequence: bytes) -> Tuple[Optional[str], bytes]: + """ + Identify and extract SIG/BOM in given sequence. + """ + + for iana_encoding in ENCODING_MARKS: + marks = ENCODING_MARKS[iana_encoding] # type: Union[bytes, List[bytes]] + + if isinstance(marks, bytes): + marks = [marks] + + for mark in marks: + if sequence.startswith(mark): + return iana_encoding, mark + + return None, b"" + + +def should_strip_sig_or_bom(iana_encoding: str) -> bool: + return iana_encoding not in {"utf_16", "utf_32"} + + +def iana_name(cp_name: str, strict: bool = True) -> str: + cp_name = cp_name.lower().replace("-", "_") + + for encoding_alias, encoding_iana in aliases.items(): + if cp_name == encoding_alias or cp_name == encoding_iana: + return encoding_iana + + if strict: + raise ValueError("Unable to retrieve IANA for '{}'".format(cp_name)) + + return cp_name + + +def range_scan(decoded_sequence: str) -> List[str]: + ranges = set() # type: Set[str] + + for character in decoded_sequence: + character_range = unicode_range(character) # type: Optional[str] + + if character_range is None: + continue + + ranges.add(character_range) + + return list(ranges) + + +def cp_similarity(iana_name_a: str, iana_name_b: str) -> float: + + if is_multi_byte_encoding(iana_name_a) or is_multi_byte_encoding(iana_name_b): + return 0.0 + + decoder_a = importlib.import_module("encodings.{}".format(iana_name_a)).IncrementalDecoder # type: ignore + decoder_b = importlib.import_module("encodings.{}".format(iana_name_b)).IncrementalDecoder # type: ignore + + id_a = decoder_a(errors="ignore") # type: IncrementalDecoder + id_b = decoder_b(errors="ignore") # type: IncrementalDecoder + + character_match_count = 0 # type: int + + for i in range(0, 255): + to_be_decoded = bytes([i]) # type: bytes + if id_a.decode(to_be_decoded) == id_b.decode(to_be_decoded): + character_match_count += 1 + + return character_match_count / 254 + + +def is_cp_similar(iana_name_a: str, iana_name_b: str) -> bool: + """ + Determine if two code page are at least 80% similar. IANA_SUPPORTED_SIMILAR dict was generated using + the function cp_similarity. + """ + return ( + iana_name_a in IANA_SUPPORTED_SIMILAR + and iana_name_b in IANA_SUPPORTED_SIMILAR[iana_name_a] + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/version.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/version.py new file mode 100644 index 00000000..98e53fb3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/charset_normalizer/version.py @@ -0,0 +1,6 @@ +""" +Expose version +""" + +__version__ = "2.0.7" +VERSION = __version__.split(".") diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/LICENSE.rst b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/LICENSE.rst new file mode 100644 index 00000000..d12a8491 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/LICENSE.rst @@ -0,0 +1,28 @@ +Copyright 2014 Pallets + +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/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/METADATA new file mode 100644 index 00000000..2c8da01a --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/METADATA @@ -0,0 +1,111 @@ +Metadata-Version: 2.1 +Name: click +Version: 8.0.3 +Summary: Composable command line interface toolkit +Home-page: https://palletsprojects.com/p/click/ +Author: Armin Ronacher +Author-email: armin.ronacher@active-4.com +Maintainer: Pallets +Maintainer-email: contact@palletsprojects.com +License: BSD-3-Clause +Project-URL: Donate, https://palletsprojects.com/donate +Project-URL: Documentation, https://click.palletsprojects.com/ +Project-URL: Changes, https://click.palletsprojects.com/changes/ +Project-URL: Source Code, https://github.com/pallets/click/ +Project-URL: Issue Tracker, https://github.com/pallets/click/issues/ +Project-URL: Twitter, https://twitter.com/PalletsTeam +Project-URL: Chat, https://discord.gg/pallets +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +Classifier: Operating System :: OS Independent +Classifier: Programming Language :: Python +Requires-Python: >=3.6 +Description-Content-Type: text/x-rst +License-File: LICENSE.rst +Requires-Dist: colorama ; platform_system == "Windows" +Requires-Dist: importlib-metadata ; python_version < "3.8" + +\$ click\_ +========== + +Click is a Python package for creating beautiful command line interfaces +in a composable way with as little code as necessary. It's the "Command +Line Interface Creation Kit". It's highly configurable but comes with +sensible defaults out of the box. + +It aims to make the process of writing command line tools quick and fun +while also preventing any frustration caused by the inability to +implement an intended CLI API. + +Click in three points: + +- Arbitrary nesting of commands +- Automatic help page generation +- Supports lazy loading of subcommands at runtime + + +Installing +---------- + +Install and update using `pip`_: + +.. code-block:: text + + $ pip install -U click + +.. _pip: https://pip.pypa.io/en/stable/getting-started/ + + +A Simple Example +---------------- + +.. code-block:: python + + import click + + @click.command() + @click.option("--count", default=1, help="Number of greetings.") + @click.option("--name", prompt="Your name", help="The person to greet.") + def hello(count, name): + """Simple program that greets NAME for a total of COUNT times.""" + for _ in range(count): + click.echo(f"Hello, {name}!") + + if __name__ == '__main__': + hello() + +.. code-block:: text + + $ python hello.py --count=3 + Your name: Click + Hello, Click! + Hello, Click! + Hello, Click! + + +Donate +------ + +The Pallets organization develops and supports Click and other popular +packages. In order to grow the community of contributors and users, and +allow the maintainers to devote more time to the projects, `please +donate today`_. + +.. _please donate today: https://palletsprojects.com/donate + + +Links +----- + +- Documentation: https://click.palletsprojects.com/ +- Changes: https://click.palletsprojects.com/changes/ +- PyPI Releases: https://pypi.org/project/click/ +- Source Code: https://github.com/pallets/click +- Issue Tracker: https://github.com/pallets/click/issues +- Website: https://palletsprojects.com/p/click +- Twitter: https://twitter.com/PalletsTeam +- Chat: https://discord.gg/pallets + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/RECORD new file mode 100644 index 00000000..3471ffe8 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/RECORD @@ -0,0 +1,41 @@ +click-8.0.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +click-8.0.3.dist-info/LICENSE.rst,sha256=morRBqOU6FO_4h9C9OctWSgZoigF2ZG18ydQKSkrZY0,1475 +click-8.0.3.dist-info/METADATA,sha256=_0jCOf3DdGPvKUZUlBukeb1t6Pnxmm_OMGpaBoDthfc,3247 +click-8.0.3.dist-info/RECORD,, +click-8.0.3.dist-info/WHEEL,sha256=ewwEueio1C2XeHTvT17n8dZUJgOvyCWCt0WVNLClP9o,92 +click-8.0.3.dist-info/top_level.txt,sha256=J1ZQogalYS4pphY_lPECoNMfw0HzTSrZglC4Yfwo4xA,6 +click/__init__.py,sha256=YkIrDg7-0g5aBS6D2pDe58j3MOaFylHED2_8OXh2fnM,3243 +click/__pycache__/__init__.cpython-39.pyc,, +click/__pycache__/_compat.cpython-39.pyc,, +click/__pycache__/_termui_impl.cpython-39.pyc,, +click/__pycache__/_textwrap.cpython-39.pyc,, +click/__pycache__/_unicodefun.cpython-39.pyc,, +click/__pycache__/_winconsole.cpython-39.pyc,, +click/__pycache__/core.cpython-39.pyc,, +click/__pycache__/decorators.cpython-39.pyc,, +click/__pycache__/exceptions.cpython-39.pyc,, +click/__pycache__/formatting.cpython-39.pyc,, +click/__pycache__/globals.cpython-39.pyc,, +click/__pycache__/parser.cpython-39.pyc,, +click/__pycache__/shell_completion.cpython-39.pyc,, +click/__pycache__/termui.cpython-39.pyc,, +click/__pycache__/testing.cpython-39.pyc,, +click/__pycache__/types.cpython-39.pyc,, +click/__pycache__/utils.cpython-39.pyc,, +click/_compat.py,sha256=P15KQumAZC2F2MFe_JSRbvVOJcNosQfMDrdZq0ReCLM,18814 +click/_termui_impl.py,sha256=z78J5HF_RTsOBhjNLjoigaqRap3P2pWwEDDAjoZzgUg,23452 +click/_textwrap.py,sha256=10fQ64OcBUMuK7mFvh8363_uoOxPlRItZBmKzRJDgoY,1353 +click/_unicodefun.py,sha256=JKSh1oSwG_zbjAu4TBCa9tQde2P9FiYcf4MBfy5NdT8,3201 +click/_winconsole.py,sha256=5ju3jQkcZD0W27WEMGqmEP4y_crUVzPCqsX_FYb7BO0,7860 +click/core.py,sha256=k4PA2z0BT_dmed9I52Q2VLi8r6ekTMCtCQzw2y915Xs,111478 +click/decorators.py,sha256=sGkXJGmP7eLtjtmPl_Un2uBTlrhK8s2L22n-yBiDwTw,14864 +click/exceptions.py,sha256=7gDaLGuFZBeCNwY9ERMsF2-Z3R9Fvq09Zc6IZSKjseo,9167 +click/formatting.py,sha256=Frf0-5W33-loyY_i9qrwXR8-STnW3m5gvyxLVUdyxyk,9706 +click/globals.py,sha256=kGPzxq55Ug4dFUrgRV-5oHVPOPdLCUhmYolbrrVBo8g,1985 +click/parser.py,sha256=cAEt1uQR8gq3-S9ysqbVU-fdAZNvilxw4ReJ_T1OQMk,19044 +click/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0 +click/shell_completion.py,sha256=_hPI12T9Ex-y5a3WunWnlH0Gca2_urzXFXkDnt7G6Ow,18001 +click/termui.py,sha256=Rp2gFE8x7j8sEIoFMOcPmuqxJQVWWTrwEzyC14-sPAw,29006 +click/testing.py,sha256=kLR5Qcny1OlgxaGB3gweTr0gQe1yVlmgQRn2esA2Fz4,16020 +click/types.py,sha256=VoNZnIlRBAtRRgzavdqVnyfzY5y4U4qzVGI1UvvX1ls,35391 +click/utils.py,sha256=avYwX-3l2KkdJNUo8NmncZSoAdEmniQ_M5sdsSYloJ4,18759 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/WHEEL new file mode 100644 index 00000000..5bad85fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/WHEEL @@ -0,0 +1,5 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.37.0) +Root-Is-Purelib: true +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/top_level.txt new file mode 100644 index 00000000..dca9a909 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click-8.0.3.dist-info/top_level.txt @@ -0,0 +1 @@ +click diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__init__.py new file mode 100644 index 00000000..a2ed5d13 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__init__.py @@ -0,0 +1,75 @@ +""" +Click is a simple Python module inspired by the stdlib optparse to make +writing command line scripts fun. Unlike other modules, it's based +around a simple API that does not come with too much magic and is +composable. +""" +from .core import Argument as Argument +from .core import BaseCommand as BaseCommand +from .core import Command as Command +from .core import CommandCollection as CommandCollection +from .core import Context as Context +from .core import Group as Group +from .core import MultiCommand as MultiCommand +from .core import Option as Option +from .core import Parameter as Parameter +from .decorators import argument as argument +from .decorators import command as command +from .decorators import confirmation_option as confirmation_option +from .decorators import group as group +from .decorators import help_option as help_option +from .decorators import make_pass_decorator as make_pass_decorator +from .decorators import option as option +from .decorators import pass_context as pass_context +from .decorators import pass_obj as pass_obj +from .decorators import password_option as password_option +from .decorators import version_option as version_option +from .exceptions import Abort as Abort +from .exceptions import BadArgumentUsage as BadArgumentUsage +from .exceptions import BadOptionUsage as BadOptionUsage +from .exceptions import BadParameter as BadParameter +from .exceptions import ClickException as ClickException +from .exceptions import FileError as FileError +from .exceptions import MissingParameter as MissingParameter +from .exceptions import NoSuchOption as NoSuchOption +from .exceptions import UsageError as UsageError +from .formatting import HelpFormatter as HelpFormatter +from .formatting import wrap_text as wrap_text +from .globals import get_current_context as get_current_context +from .parser import OptionParser as OptionParser +from .termui import clear as clear +from .termui import confirm as confirm +from .termui import echo_via_pager as echo_via_pager +from .termui import edit as edit +from .termui import get_terminal_size as get_terminal_size +from .termui import getchar as getchar +from .termui import launch as launch +from .termui import pause as pause +from .termui import progressbar as progressbar +from .termui import prompt as prompt +from .termui import secho as secho +from .termui import style as style +from .termui import unstyle as unstyle +from .types import BOOL as BOOL +from .types import Choice as Choice +from .types import DateTime as DateTime +from .types import File as File +from .types import FLOAT as FLOAT +from .types import FloatRange as FloatRange +from .types import INT as INT +from .types import IntRange as IntRange +from .types import ParamType as ParamType +from .types import Path as Path +from .types import STRING as STRING +from .types import Tuple as Tuple +from .types import UNPROCESSED as UNPROCESSED +from .types import UUID as UUID +from .utils import echo as echo +from .utils import format_filename as format_filename +from .utils import get_app_dir as get_app_dir +from .utils import get_binary_stream as get_binary_stream +from .utils import get_os_args as get_os_args +from .utils import get_text_stream as get_text_stream +from .utils import open_file as open_file + +__version__ = "8.0.3" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..11250444f923d7a928ecff673ca362ceab4fda0f GIT binary patch literal 2664 zcmd7U*HRlv6b4`cN=PCH6U`WmF-c^TqX@=JDg!sCsG1thG*T~6C)iin+Beee zUhOORYR@?$c;8^5`1!hLx_joRrIFRtl!@Wb&!11$U%6Q9Z)*JdQ;&@u{L`}yv6vHs zm{aG}yLDbY)Yp+4&<)VQj-%rcXD84JNU)RWBqZ4>bP7`JG&&7wb|bnG8rd0i1~Tld zoAq*#W9QIK(8O*+H$yYK8QlUc>=tw@w6a^#ZP3PUL$^aayB*yD9qbNtCv>tq(OuBR z?m~A%H@n+?=k-7j`yIL$df7ebKImijqWhtr-G?540d_xn5C+);==boRJ%}EHA@+N; z0S0@>{ooD5Fxx`^8&^ zW%e9;1y16_audlS76`|K_Ez&nIP_BQ$mj@Ucsuke+9_8$5hd}9~Tzrk

$%XMCqcSdw>sIVCE?$zhK`Tm~ z!Q)||t)eUPnSbi=b78!$n%-5ViYNRCo!!HQ3biZ5X6lV?&nyJ4E9^)He(ks)i61mF zafBBaB66n{HxvzA;NME+Sv1DPBGwj4l%8kL zmW3O>^>Up!hqU)k1y%QdxpqFYa4r(NbrlCD+p?J{;I zLaU3u5_SJETL zsc6#SP@-g^788Y@!1hgbXCE( zGa`F^cJckZaBz8fu#e67_4P6Tf4xkyJ*mP!Y?c9!(u7 zVRS!&#EcYbOPHnt8v`VLeT?U;j=rY z;uHyrBt?oMP0>g}UjrcX`Xu=K&@oRJ5UW{1Cq3*DpHML zLw%$erT9cKM)8?qoMM7vl46Qtnj%jzgHcUH_zG(^OC56*^Armdixf)~UnrI-Rwz~} z)+p8~HYheRs)%cq6;XH1>a0g9i?&e~1Mt(07G z6F%Mx|9&CAdUGO+H(EwwI<)LNe1qv5n;tAPrYU_HnPxtGtfn_=&lG$-;y1QGFyhHv J-T&aX{$Jr3zu^D? literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_compat.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_compat.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7533486cd2d6337806e11d91c2964e042fb10c0f GIT binary patch literal 16013 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 z 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_unicodefun.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_unicodefun.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..51851501cc7d6504a869cf185523c42bb83f8174 GIT binary patch literal 2301 zcmZ8i&2QX96!&<&UdP$=BTdo|Dm2_!(QI1LLx=!1gcMbZN<>=Gu7Xxx&+M)fug9Gk zZ?a~6DB*yRD)okt5ZXP`V=r8g_&?^#iGQK3RNmO$Hq_F5y*KZ@-}@SS3k$9R--{Qi z_qc8t|LDW%uL6f#Fhmn3Vh|J>tztzj1ZOie2WG2+fI}+3A!3p0k5k(DVb zcNeFqYXZvanLBnt|8VTS#aNuPxv@*E1i|S6GM=JGKf`!1o-1k3O1qb|U7%hrtjWvd z%4B(LPSFYa0ip|Oe=ohU9f^cffo0#5Fi}jSVZd25ppnFZz&*wY?lO+=M}f}>ZE{Gu z0oAbtg%WexrJPejBj5#5PgOnP2f^L+@2xQK5AjhDhS=*cE^#;Epq^uTO#MU#EW#b? zdx@ZUcO?68Jn{tgS=0@B0El48ux4)VZQZ$pfi*LcgLwyN6K^r_Bb2x=Wh^$<)_iTg z8GB(!rHDB@puQAMpAFWM!jDyv#4+Gn%k>Qc8T7mym5?+RO;wGV2#%E! z#%UaSK5baa7Lu?;<|_n1IWu(1h9l!b8Mhl|YBv+vU0qMBdR^B9Ki{Rbd|h3?m;Sm* z2pDIP7vdm-Ko4>l8yF%Y`;Y)J0z?BGF)WfmdYzEs`}c0IuHyokz(`0$Z z*W%FQfz~26(i<4QLI&?_wKsQmJ}VKqr#YK10f->Y%mLD>6|t>i)!8v zfD-#&gkxRHUCstNxD+a82JlTvW@7IoV*`I*aUP&3;&CS_8n#e4s}r9kA%SX<1?VKsapOQ|p=dYQ5(dSf@6cliMd8#N zGo?OAXNmm-p5?|s5Qti=j2C3Nfp`txgVc20#+7`_EjTM%zZJgF{lgBESXq%bplWXW z*r&0sc7@u?WJ0+j=|Fq>R0vhwWigGEwR>lGTg~fA(!J_Qs%l^FZR@sD6+tD)#9<)A zAfg~6BoAU$g@U1Z8xnC8$iAw0gecpKK_RR~TPf>+1rhWt)EXtKR#um)z)Pm;-z1R? z1~j+Rn9sdv*oq%y@gHG`iOonNqy19tz$Tb~gRZL{QHeXwFb>slYLN*Kw0rjP0 zn=hQ2z6Uf@^UuJ(j%>5M0dlsZ@0U89I&k#fvg)s_*Op_MSJ4W{x*+G4_pGY<5_ofb t6|gj_{2VNNSx=^(mh_}qc@$1f*MO#+PX~-7A^lwcWQ6v~K@O@{{sY=j!#@B3 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_winconsole.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/_winconsole.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..789671216a965bdfb673c11f93a56ea38d811ac5 GIT binary patch literal 7757 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/core.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/core.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9087b7b08efccc5b30e6b3967443bfaa957bb93a GIT binary patch literal 88485 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/decorators.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/decorators.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7a1bfc4aeb5022aade4128b94e89517b41776844 GIT binary patch literal 14267 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 TZNlGg9kgIA{-NIgR@MIj(u@vb literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/exceptions.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/exceptions.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..820b1ddca8c3bd4bfc3df6f47640215619184534 GIT binary patch literal 10105 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 J8x_3H{{sKn3BUjV literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/formatting.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/formatting.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..ca5b985f97b0cc4badd1327a4614cf94110370fd GIT binary patch literal 9385 zcma)C&2t+^cJH1U3GWf^+GA$mxH z8VtamfheNDN>wPArGqL?Rc_W+QMviDhum`5J>*ZwaSplUq+D`HPV$zW-+Mg(2nwnV zP}7*{>3;oQ_v_#LXatj!Wr5F=C*9z`UK8R!>EY+E9FpbPlS~P5l*V&6@jNITqnZmaC*a9 z5U8i8it^}5l^$BEtS0U{D<{Xate|ej^fv9$qw>&JlWGb*PN}n?S|Q5eY&flE9=ht3 zn!Q_CIsK7Pr`6nDq2>;(l{rv26HezNqb-ko1|!d_1<;vS@^evr?lB}6%T<|8)mw2I z-btH59BhUfHO0*^rJBbQP4Micp>EcqFvfi;X-AE;)@r9&<=Us8eemH@?dJ8R8y_!L zt<2G_-6V5$n09nrr_TLP0XIclAK*%EplFDF*%M3Ri%a`fDtgv|#QnKdYv0~?QrVM- zR?k-Qk(Js#=Rh7Izk^5H9`jwDk$5H})BsrA*$*hkJl)Y*)})%M=)FuwiM z#dlUeX{@g%jWoR24(hisZ^>#sYSeGNzR}XnAWa+b=3;v>9Ua!vU_A;KuSBhS5G7X^2TiNRtQ5wbW~hTS%*A{8N?t|5OL~^3R$&p%!p@6XaYpb|J3Q4EX&vd6 zO)6!E(a)o|o~L3k@rK(HB-Az1ELy$9K_P5U>X-2Qco~I$0mZedn>nPjS%K#un`*?3 zv=KzLMy$d(%}yqr^(5Ts;J#mVs;$E$)VIT0JJ7+V4%%CZk&$M)|DpLI!C8sULcf#* zNQkD~2Qc)+q4h}YiyoA*M=EP8=Yg~D_MGI+o_lEb#3Lx?rnqn65~^@ts)BMK%CE#% z@+)h@Rz>CAt?U;;$9Y8C;r)HD=Oyi4@c^nx?RQr1p-)HXe}ck$2XepE^GNN{u4HQF z#eI2C92R@tBMEh0HGMb5e)*mSifgO(eYrmY9^FGvmF~$|@bnLFf%gghAH6dAxrZg< zlX}O~c@1+;H8;V9BOGyHgZA&<5MRs0xdh(m`)gb~zfNkKgQPjYONTWS}7t@{iv|@|C|Nfq@!i}I4r5F50TK4e?k_0;d zEx2pyw?GivA@M;j@DuE>DD(&G=C?MOmcQP?K)BxunabLjC0^rh%@AtkHxj?CTell3 zR2bObZA8&1pG;*dh}F^268}8dZN%ubzUQaAEkA6w(>*^zRZ?9nbEoSYL-rCs(4lY0 zs0-kK$ap=7{dGv9LGTU;?l#gbA9YNT2@zGFFgk!r$D1UZzqYozzP9Gqx1hLn668E; z?p%6%ZLR93Er_5Rb<7se9utXMz7A>5+e9MSYIPz7hT82gMr$+6>p-GgIro=|!zRz^ zWgd}M$~4P6gXx@Ns1|vQybtd`(+SYkXm*+q3b5n@8V96CdW>#W(>1RnQJ^r#M{Y+! z9h1eXWmcMWX3S@!p_7ys1{y_*lWKzIqx?Pv41ET8VAJ85<1?W#MQ|HSzIs5a*+I8?vH@S+J-0mu_K zu*x?{OG14O$ovYbHQ{S4%iNqt+zX#l0 z5QpLsT&!D`zH-kxl=o!&9MBY)d1&E%L5VNnBt4QFHe=D*yv;SVaaEDp^xvU1zF%5D zM+w~VjNyMGy&IV?72rx)?QTG21#N1vl& zuw42zdgSqntS+I}KSfpM&@d}rOE)&jpUW(L8_q(oYh-_&dhrC52J(?{O|GI43l+Er zR{#4)*L7ssqB(J_xl#qcu5{6Yz7>33yqm&&IdaB&6AKOsbs}^0L%zeixRNQ@)sP+V z6$?(at$q|bVPV@19k{XiFX_ocIO58M%UcXRJQv~A!luEgE#ayBP^t-4!BaVZGLG|v z`f=#tOLRQA)V7)ios((?bSg~e6zI&V)95*w_ncE_@HEA5=kazyoyGGBbskivah)WJ zxr6V74thNgnlGpqL31WN#iPwC8>791-oASIF5K9a(|A+ZHuc2qIrR$H&tV*TepS7O zQO+nEI$g~sKZY5-X8cJQzdvA(ZfpS!>Jf}1+t|dIi=ofSfPHa2NC1vxgt61%n!>_f zPk)>+R&J9h8y_#;SsX4@b4dWT3?@ z8YF2MXjI|tFd`cb_F%nsHBf@ks-gYXZtQOaaedEkb<%bx1?Dh`_foQY3DBL4K1lBd zdk~0vCd5Gtj&if5_eL#Jz5yC>U58EdHDDbm1#hoKEDzqWSPZ}sF*ky`M{Lv>+vNK^ z&$&wiAB2R2IEaE87-9_O8X{PjW*d`&_JQBGeeg_v_O==PG5OBRRVSN1E(P!3tb{%_ zCS`z?eO+{+54oiD`~j}yHz)v#A`<%!98Xb0bfg5F#Ip(!R1Xmi?mtc~cEruSojN_| zu<%H1yFL2=5!5`Q+5>KZ{zbU!qULSFp{`M^i14A)j1wc_RK24$R;}-XyMW*g#GHl9Ny2Eu z5M?ZTmnf64$KwI7hR%pUYZ@;(CJ?S?xj-E!zs?d8$?n|9_F3$AL!9awqyBU}L+fMX z;z^#yO;2o#LqsxUk2q|$x^LVx8XEYWxKVGZF!w2p%95UtqszO;2)DRgwe-gz#(<9d z>vaDYR2&O+3atEJ;!Q%F2&;Q)R0e*p&*Rldj0<2GvOSB39#mzUn3q2jmZ>h7j)^tvsp3?I6%a%bKvT4W=^0tk)$vV_tX1~G@4>*R)Ig@hVl^DO>-$6 zmjn3?%*StOkHHwx{C*>TYkh+~$o0rwpw6QDd9h#U6-@R*70!rT1syBfJkJUQhzR%) zzF7zyot~@Q2M)VD?^At`@99nzS@G-??YAX*+ms7Y-Wi0{BQ)G0jU)XiBrA3Qd#JDp ztbuWc8DB|Ra~(C1OkQj5#nW6FY^6Jj1>&F?8XP;)j3)E4KXeM=s#4^D)C9(Xg#r4Z z2_m_eaGyHTXD|i@J(q#D{QzhXBMklaMSsbJhJ?cd3PfdX?c6U(qRaldwY4Gf<*sY0 z*$sOluRf+NfqnN1e%PDUKf&E&LQ|w#WX&i(qYk00{)7thR~Xr+UDKSQxn z>Cn(MqefYoT)`Z=X`3A1*%Q2TYux7_@jfBnO_V)3WzEZqHEogqH1w^UAKY?TmgPLx zdOtWnIBs`gbh{m)2uLe#g@Hn3Gal1OELLa|5(+}bgVl6YeOcKYC{3aJ@<3^F!b5n= zHHLSU{u~6m*5xu`9M2npNFU>Vjr-#>F=_bDss1Zk^x@>Waq{Ku{uHWg3q1|FBvOVF zNNqs|yZg#OhGDpUT<=*G1^~?xjDwmJhU)>H-xJ?#o?&^qFO1`S&=#}7E;@xpPi4=j zl2?YTD;eQ!+S*u~Lzz<2Q*6VW!=S@pKPZrFETzLz79geD4RR@Uc+ns*IUp3Q9~U+E zYD~}$S1wkA-P8|4kqsGS!iF1)_tA}`;h>2xXcxhoG23UjX-LP=m@NnkK5j#l&4d!8 z|AzL)jyvUi7vy{4JLr9>J3nrAspI1pX(Y#_Dap^M!GFpo=!OE+!EQL}Mpe*d0Pml` za3V*EOaQ%4k-OV2_X=?5V04rRm(EKkddLQ^buTl^r59<&ksqcwwNvv}sHXLauQ?)FxHRcL>R1R1%ZS$$6?V zV_+lFFe%g$$nX8pbo&4o&x?|W5N#Xo3t-ghKK~h?p_(|&I9x^&T2m9xSe*Yef#o=t z#X~I4;5J80TEyg2O5Se*bA1)>m&p;LgdhEWfnTnz&S!|ZNlR+AtX!)#TdEV$eWh00 zK{6?SQ>@igtBz_LFrUdZ^FC!j4-nwMy;0&-s+D9%h9b z1loFo8WI1QcO8LskOF(QsIEc9HWfpyh}DaJ3a4 za0mxig4{V6*2R4r&ITel1w)HS5iSK1;pdfu_mbT`I37KFgPnz)N>6Uvoa_{;_&~y` z^$-ujq~C?ZLMPsjaNxK>j_yP-0VY1e=>naM^`kDsWS*NKJ;LUu7~HpUU;;n?_^bNtZ`WP1^KogdiXn#rXY1PbE4JR+(!l3Id1y z=HociC-CCpfT@?B!Bqcm2>7P}CEYm{Wh}Zw|0FPH2?c$d-d#qqa%#+4W;Ued@b~!i zRE`e&9JonlKt$k(fc{fJ2M3Ntc2@UL3p3*5$2cJbH`l5QnVas>(WGwUIV}s z3U9x`-{CdB!0XR_zQ`NTs!vI8$?b27CVaol7q&ci+AL4`)>|jbc+y(}D}=9romIZ} zEa+t!(&jNdk?%< zr27gcjltCQa(Z)LyV3q~?@lz_GjQ#v2@4;wu`qj~jKW8sjinj_ zigt38T^tMB4^yoHL_f^&Ht{|mCePPPFt`67m406uzJQGUW7`{ z%X=WqH>~%9aAN)a3ir3Xm;O)Sci`E;R!9EP55#*+h&R7-?3tSus^cj+CQm@;p~r*A z8-^#$*a1H+0ZdF&u$ztjcsdu$a?R1M@Uvkz_-e=T1QE zM=X^Xq#^{M1D9zQ89~{3MmpjUGI&3YZ8R0Pv{ri1c6zSoU;hnb{{AkO2SNit3~~t- zaJCq`t%Z!(EC`tacIZ1|$*RUeCub|)TC1aBYIE~hV<+a~&|Q@^PhZ^f9ZzIL{7V)3 zq$4k5M`E*kt3KHv7f3*;51dp9?V+y0_L)9KCPET&eYy#P_4dgNpOZ0k=!?p+_mU9c zaOk(n{F8f70RoFY76)a(%Mve}&-v2UYhbF|3iK+xvwFYJqtN#ISp%|K#6GLBBoQ%h z5q$}i-f|^tV!4&g(guZ+yS6}vZ=5F}o*BqG&XW}oa!+0Y**ZS==O5k|Q#Atzu$Zh$ zs1!2+U4^}kTRHS@tKv{Q7qUvCl2g!5$S+%hgA(2ixUGbD6=aBZHB?gR|Hc~;R^V|c zKL+6#(4|B-kAV#>M4DHABaeam-0la*WFP)T4u3HJeFu9vX0jjw3_TFN!(JA2-W+P= zHXQ~!l57kVvok6R`=o!6j*u4YN2cg4SOEtiM+kn6DhP@`z>aV#QmIF%khqAs+Q+Ds zi7)xq9dvg!{xP6Z@mHhY&1HO@o9s)#P)g1O1QepyFP!-T)bmQN)=A(u{5q-m`aQHo zZnsF=&E3{|R6$_u;);{q65>ZU4B_{jRs3>-OOfE@Gr2 zllfLaM*@$#RxU~w3PnrBxN{&2hDyn-em6mWW>RAjYD~3*b8dmuznUtZO7S(em_gU; Yq)wWCEuSj^*$4u1CD`0ttFBc40U5$+<^TWy literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/parser.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/parser.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..e397d0c3572f7e9311c156876f40a0ffd40267e5 GIT binary patch literal 13540 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 KM5&=07*R2H6|7o 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/termui.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/termui.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..3a2bce412fe6bfc1a0d6ab23d385de5ca2339e89 GIT binary patch literal 26541 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/types.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/types.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fcac5c310f45da7d3b33a4e6632e836c1de14358 GIT binary patch literal 32871 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 I^Dpy%07&jQy8r+H literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/utils.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/__pycache__/utils.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c8d0feffd813df80654600bd2a595c94e03aca25 GIT binary patch literal 17745 zcmc(HTW}oLnO@)Kg5eMZAxb25bDNd~LMDflCCf5ak$DA0ivk&wGHsalpfRTb4A?Ub zp6($DWTCcd8Ji!Iav9~?d`-#~ zl=sZHjFBJ~)2}cZbz}T%T5xxIVMw9JbUGA3F2ThR=o1 zsRIuj^`v_018@HM@Y(QLbrAQ5)M4CzhP6@SX*_vGJ&Py4dK+y%i)YV2aMfp&|3PW~ z$OTJ%Rvr1kQb+DP^Pj`r=hO?hdjWSZsEdH{BH!^Ae&!=TfpI67wC@YD%)60MG@cQ_M)I9$v0@{;<(gNk}p zy@r~{QKvyj>WdF-^}6~JdN`pj;ps`VerS zJvEnN-3+=(8O}=*w6>i=p#!%jh{!ashJzgQExd4Z>+7~4!gHsZG8F0rS{^D1gJZ{7PM{#%VBb( z6}4M8PxR7ulr+}Xv$5t{oV4$@m(~d+fq=0rTR)5IG={#^>$dchxEUEYE0yqd@lBq` z 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 V*Kh}Dzo@@1b^n6NNqMVB{} str: + return sys.getfilesystemencoding() or sys.getdefaultencoding() + + +def _make_text_stream( + stream: t.BinaryIO, + encoding: t.Optional[str], + errors: t.Optional[str], + force_readable: bool = False, + force_writable: bool = False, +) -> t.TextIO: + if encoding is None: + encoding = get_best_encoding(stream) + if errors is None: + errors = "replace" + return _NonClosingTextIOWrapper( + stream, + encoding, + errors, + line_buffering=True, + force_readable=force_readable, + force_writable=force_writable, + ) + + +def is_ascii_encoding(encoding: str) -> bool: + """Checks if a given encoding is ascii.""" + try: + return codecs.lookup(encoding).name == "ascii" + except LookupError: + return False + + +def get_best_encoding(stream: t.IO) -> str: + """Returns the default stream encoding if not found.""" + rv = getattr(stream, "encoding", None) or sys.getdefaultencoding() + if is_ascii_encoding(rv): + return "utf-8" + return rv + + +class _NonClosingTextIOWrapper(io.TextIOWrapper): + def __init__( + self, + stream: t.BinaryIO, + encoding: t.Optional[str], + errors: t.Optional[str], + force_readable: bool = False, + force_writable: bool = False, + **extra: t.Any, + ) -> None: + self._stream = stream = t.cast( + t.BinaryIO, _FixupStream(stream, force_readable, force_writable) + ) + super().__init__(stream, encoding, errors, **extra) + + def __del__(self) -> None: + try: + self.detach() + except Exception: + pass + + def isatty(self) -> bool: + # https://bitbucket.org/pypy/pypy/issue/1803 + return self._stream.isatty() + + +class _FixupStream: + """The new io interface needs more from streams than streams + traditionally implement. As such, this fix-up code is necessary in + some circumstances. + + The forcing of readable and writable flags are there because some tools + put badly patched objects on sys (one such offender are certain version + of jupyter notebook). + """ + + def __init__( + self, + stream: t.BinaryIO, + force_readable: bool = False, + force_writable: bool = False, + ): + self._stream = stream + self._force_readable = force_readable + self._force_writable = force_writable + + def __getattr__(self, name: str) -> t.Any: + return getattr(self._stream, name) + + def read1(self, size: int) -> bytes: + f = getattr(self._stream, "read1", None) + + if f is not None: + return t.cast(bytes, f(size)) + + return self._stream.read(size) + + def readable(self) -> bool: + if self._force_readable: + return True + x = getattr(self._stream, "readable", None) + if x is not None: + return t.cast(bool, x()) + try: + self._stream.read(0) + except Exception: + return False + return True + + def writable(self) -> bool: + if self._force_writable: + return True + x = getattr(self._stream, "writable", None) + if x is not None: + return t.cast(bool, x()) + try: + self._stream.write("") # type: ignore + except Exception: + try: + self._stream.write(b"") + except Exception: + return False + return True + + def seekable(self) -> bool: + x = getattr(self._stream, "seekable", None) + if x is not None: + return t.cast(bool, x()) + try: + self._stream.seek(self._stream.tell()) + except Exception: + return False + return True + + +def _is_binary_reader(stream: t.IO, default: bool = False) -> bool: + try: + return isinstance(stream.read(0), bytes) + except Exception: + return default + # This happens in some cases where the stream was already + # closed. In this case, we assume the default. + + +def _is_binary_writer(stream: t.IO, default: bool = False) -> bool: + try: + stream.write(b"") + except Exception: + try: + stream.write("") + return False + except Exception: + pass + return default + return True + + +def _find_binary_reader(stream: t.IO) -> t.Optional[t.BinaryIO]: + # We need to figure out if the given stream is already binary. + # This can happen because the official docs recommend detaching + # the streams to get binary streams. Some code might do this, so + # we need to deal with this case explicitly. + if _is_binary_reader(stream, False): + return t.cast(t.BinaryIO, stream) + + buf = getattr(stream, "buffer", None) + + # Same situation here; this time we assume that the buffer is + # actually binary in case it's closed. + if buf is not None and _is_binary_reader(buf, True): + return t.cast(t.BinaryIO, buf) + + return None + + +def _find_binary_writer(stream: t.IO) -> t.Optional[t.BinaryIO]: + # We need to figure out if the given stream is already binary. + # This can happen because the official docs recommend detaching + # the streams to get binary streams. Some code might do this, so + # we need to deal with this case explicitly. + if _is_binary_writer(stream, False): + return t.cast(t.BinaryIO, stream) + + buf = getattr(stream, "buffer", None) + + # Same situation here; this time we assume that the buffer is + # actually binary in case it's closed. + if buf is not None and _is_binary_writer(buf, True): + return t.cast(t.BinaryIO, buf) + + return None + + +def _stream_is_misconfigured(stream: t.TextIO) -> bool: + """A stream is misconfigured if its encoding is ASCII.""" + # If the stream does not have an encoding set, we assume it's set + # to ASCII. This appears to happen in certain unittest + # environments. It's not quite clear what the correct behavior is + # but this at least will force Click to recover somehow. + return is_ascii_encoding(getattr(stream, "encoding", None) or "ascii") + + +def _is_compat_stream_attr(stream: t.TextIO, attr: str, value: t.Optional[str]) -> bool: + """A stream attribute is compatible if it is equal to the + desired value or the desired value is unset and the attribute + has a value. + """ + stream_value = getattr(stream, attr, None) + return stream_value == value or (value is None and stream_value is not None) + + +def _is_compatible_text_stream( + stream: t.TextIO, encoding: t.Optional[str], errors: t.Optional[str] +) -> bool: + """Check if a stream's encoding and errors attributes are + compatible with the desired values. + """ + return _is_compat_stream_attr( + stream, "encoding", encoding + ) and _is_compat_stream_attr(stream, "errors", errors) + + +def _force_correct_text_stream( + text_stream: t.IO, + encoding: t.Optional[str], + errors: t.Optional[str], + is_binary: t.Callable[[t.IO, bool], bool], + find_binary: t.Callable[[t.IO], t.Optional[t.BinaryIO]], + force_readable: bool = False, + force_writable: bool = False, +) -> t.TextIO: + if is_binary(text_stream, False): + binary_reader = t.cast(t.BinaryIO, text_stream) + else: + text_stream = t.cast(t.TextIO, text_stream) + # If the stream looks compatible, and won't default to a + # misconfigured ascii encoding, return it as-is. + if _is_compatible_text_stream(text_stream, encoding, errors) and not ( + encoding is None and _stream_is_misconfigured(text_stream) + ): + return text_stream + + # Otherwise, get the underlying binary reader. + possible_binary_reader = find_binary(text_stream) + + # If that's not possible, silently use the original reader + # and get mojibake instead of exceptions. + if possible_binary_reader is None: + return text_stream + + binary_reader = possible_binary_reader + + # Default errors to replace instead of strict in order to get + # something that works. + if errors is None: + errors = "replace" + + # Wrap the binary stream in a text stream with the correct + # encoding parameters. + return _make_text_stream( + binary_reader, + encoding, + errors, + force_readable=force_readable, + force_writable=force_writable, + ) + + +def _force_correct_text_reader( + text_reader: t.IO, + encoding: t.Optional[str], + errors: t.Optional[str], + force_readable: bool = False, +) -> t.TextIO: + return _force_correct_text_stream( + text_reader, + encoding, + errors, + _is_binary_reader, + _find_binary_reader, + force_readable=force_readable, + ) + + +def _force_correct_text_writer( + text_writer: t.IO, + encoding: t.Optional[str], + errors: t.Optional[str], + force_writable: bool = False, +) -> t.TextIO: + return _force_correct_text_stream( + text_writer, + encoding, + errors, + _is_binary_writer, + _find_binary_writer, + force_writable=force_writable, + ) + + +def get_binary_stdin() -> t.BinaryIO: + reader = _find_binary_reader(sys.stdin) + if reader is None: + raise RuntimeError("Was not able to determine binary stream for sys.stdin.") + return reader + + +def get_binary_stdout() -> t.BinaryIO: + writer = _find_binary_writer(sys.stdout) + if writer is None: + raise RuntimeError("Was not able to determine binary stream for sys.stdout.") + return writer + + +def get_binary_stderr() -> t.BinaryIO: + writer = _find_binary_writer(sys.stderr) + if writer is None: + raise RuntimeError("Was not able to determine binary stream for sys.stderr.") + return writer + + +def get_text_stdin( + encoding: t.Optional[str] = None, errors: t.Optional[str] = None +) -> t.TextIO: + rv = _get_windows_console_stream(sys.stdin, encoding, errors) + if rv is not None: + return rv + return _force_correct_text_reader(sys.stdin, encoding, errors, force_readable=True) + + +def get_text_stdout( + encoding: t.Optional[str] = None, errors: t.Optional[str] = None +) -> t.TextIO: + rv = _get_windows_console_stream(sys.stdout, encoding, errors) + if rv is not None: + return rv + return _force_correct_text_writer(sys.stdout, encoding, errors, force_writable=True) + + +def get_text_stderr( + encoding: t.Optional[str] = None, errors: t.Optional[str] = None +) -> t.TextIO: + rv = _get_windows_console_stream(sys.stderr, encoding, errors) + if rv is not None: + return rv + return _force_correct_text_writer(sys.stderr, encoding, errors, force_writable=True) + + +def _wrap_io_open( + file: t.Union[str, os.PathLike, int], + mode: str, + encoding: t.Optional[str], + errors: t.Optional[str], +) -> t.IO: + """Handles not passing ``encoding`` and ``errors`` in binary mode.""" + if "b" in mode: + return open(file, mode) + + return open(file, mode, encoding=encoding, errors=errors) + + +def open_stream( + filename: str, + mode: str = "r", + encoding: t.Optional[str] = None, + errors: t.Optional[str] = "strict", + atomic: bool = False, +) -> t.Tuple[t.IO, bool]: + binary = "b" in mode + + # Standard streams first. These are simple because they don't need + # special handling for the atomic flag. It's entirely ignored. + if filename == "-": + if any(m in mode for m in ["w", "a", "x"]): + if binary: + return get_binary_stdout(), False + return get_text_stdout(encoding=encoding, errors=errors), False + if binary: + return get_binary_stdin(), False + return get_text_stdin(encoding=encoding, errors=errors), False + + # Non-atomic writes directly go out through the regular open functions. + if not atomic: + return _wrap_io_open(filename, mode, encoding, errors), True + + # Some usability stuff for atomic writes + if "a" in mode: + raise ValueError( + "Appending to an existing file is not supported, because that" + " would involve an expensive `copy`-operation to a temporary" + " file. Open the file in normal `w`-mode and copy explicitly" + " if that's what you're after." + ) + if "x" in mode: + raise ValueError("Use the `overwrite`-parameter instead.") + if "w" not in mode: + raise ValueError("Atomic writes only make sense with `w`-mode.") + + # Atomic writes are more complicated. They work by opening a file + # as a proxy in the same folder and then using the fdopen + # functionality to wrap it in a Python file. Then we wrap it in an + # atomic file that moves the file over on close. + import errno + import random + + try: + perm: t.Optional[int] = os.stat(filename).st_mode + except OSError: + perm = None + + flags = os.O_RDWR | os.O_CREAT | os.O_EXCL + + if binary: + flags |= getattr(os, "O_BINARY", 0) + + while True: + tmp_filename = os.path.join( + os.path.dirname(filename), + f".__atomic-write{random.randrange(1 << 32):08x}", + ) + try: + fd = os.open(tmp_filename, flags, 0o666 if perm is None else perm) + break + except OSError as e: + if e.errno == errno.EEXIST or ( + os.name == "nt" + and e.errno == errno.EACCES + and os.path.isdir(e.filename) + and os.access(e.filename, os.W_OK) + ): + continue + raise + + if perm is not None: + os.chmod(tmp_filename, perm) # in case perm includes bits in umask + + f = _wrap_io_open(fd, mode, encoding, errors) + af = _AtomicFile(f, tmp_filename, os.path.realpath(filename)) + return t.cast(t.IO, af), True + + +class _AtomicFile: + def __init__(self, f: t.IO, tmp_filename: str, real_filename: str) -> None: + self._f = f + self._tmp_filename = tmp_filename + self._real_filename = real_filename + self.closed = False + + @property + def name(self) -> str: + return self._real_filename + + def close(self, delete: bool = False) -> None: + if self.closed: + return + self._f.close() + os.replace(self._tmp_filename, self._real_filename) + self.closed = True + + def __getattr__(self, name: str) -> t.Any: + return getattr(self._f, name) + + def __enter__(self) -> "_AtomicFile": + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + self.close(delete=exc_type is not None) + + def __repr__(self) -> str: + return repr(self._f) + + +def strip_ansi(value: str) -> str: + return _ansi_re.sub("", value) + + +def _is_jupyter_kernel_output(stream: t.IO) -> bool: + while isinstance(stream, (_FixupStream, _NonClosingTextIOWrapper)): + stream = stream._stream + + return stream.__class__.__module__.startswith("ipykernel.") + + +def should_strip_ansi( + stream: t.Optional[t.IO] = None, color: t.Optional[bool] = None +) -> bool: + if color is None: + if stream is None: + stream = sys.stdin + return not isatty(stream) and not _is_jupyter_kernel_output(stream) + return not color + + +# On Windows, wrap the output streams with colorama to support ANSI +# color codes. +# NOTE: double check is needed so mypy does not analyze this on Linux +if sys.platform.startswith("win") and WIN: + from ._winconsole import _get_windows_console_stream + + def _get_argv_encoding() -> str: + import locale + + return locale.getpreferredencoding() + + _ansi_stream_wrappers: t.MutableMapping[t.TextIO, t.TextIO] = WeakKeyDictionary() + + def auto_wrap_for_ansi( + stream: t.TextIO, color: t.Optional[bool] = None + ) -> t.TextIO: + """Support ANSI color and style codes on Windows by wrapping a + stream with colorama. + """ + try: + cached = _ansi_stream_wrappers.get(stream) + except Exception: + cached = None + + if cached is not None: + return cached + + import colorama + + strip = should_strip_ansi(stream, color) + ansi_wrapper = colorama.AnsiToWin32(stream, strip=strip) + rv = t.cast(t.TextIO, ansi_wrapper.stream) + _write = rv.write + + def _safe_write(s): + try: + return _write(s) + except BaseException: + ansi_wrapper.reset_all() + raise + + rv.write = _safe_write + + try: + _ansi_stream_wrappers[stream] = rv + except Exception: + pass + + return rv + + +else: + + def _get_argv_encoding() -> str: + return getattr(sys.stdin, "encoding", None) or get_filesystem_encoding() + + def _get_windows_console_stream( + f: t.TextIO, encoding: t.Optional[str], errors: t.Optional[str] + ) -> t.Optional[t.TextIO]: + return None + + +def term_len(x: str) -> int: + return len(strip_ansi(x)) + + +def isatty(stream: t.IO) -> bool: + try: + return stream.isatty() + except Exception: + return False + + +def _make_cached_stream_func( + src_func: t.Callable[[], t.TextIO], wrapper_func: t.Callable[[], t.TextIO] +) -> t.Callable[[], t.TextIO]: + cache: t.MutableMapping[t.TextIO, t.TextIO] = WeakKeyDictionary() + + def func() -> t.TextIO: + stream = src_func() + try: + rv = cache.get(stream) + except Exception: + rv = None + if rv is not None: + return rv + rv = wrapper_func() + try: + cache[stream] = rv + except Exception: + pass + return rv + + return func + + +_default_text_stdin = _make_cached_stream_func(lambda: sys.stdin, get_text_stdin) +_default_text_stdout = _make_cached_stream_func(lambda: sys.stdout, get_text_stdout) +_default_text_stderr = _make_cached_stream_func(lambda: sys.stderr, get_text_stderr) + + +binary_streams: t.Mapping[str, t.Callable[[], t.BinaryIO]] = { + "stdin": get_binary_stdin, + "stdout": get_binary_stdout, + "stderr": get_binary_stderr, +} + +text_streams: t.Mapping[ + str, t.Callable[[t.Optional[str], t.Optional[str]], t.TextIO] +] = { + "stdin": get_text_stdin, + "stdout": get_text_stdout, + "stderr": get_text_stderr, +} diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_termui_impl.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_termui_impl.py new file mode 100644 index 00000000..39c1d08f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_termui_impl.py @@ -0,0 +1,718 @@ +""" +This module contains implementations for the termui module. To keep the +import time of Click down, some infrequently used functionality is +placed in this module and only imported as needed. +""" +import contextlib +import math +import os +import sys +import time +import typing as t +from gettext import gettext as _ + +from ._compat import _default_text_stdout +from ._compat import CYGWIN +from ._compat import get_best_encoding +from ._compat import isatty +from ._compat import open_stream +from ._compat import strip_ansi +from ._compat import term_len +from ._compat import WIN +from .exceptions import ClickException +from .utils import echo + +V = t.TypeVar("V") + +if os.name == "nt": + BEFORE_BAR = "\r" + AFTER_BAR = "\n" +else: + BEFORE_BAR = "\r\033[?25l" + AFTER_BAR = "\033[?25h\n" + + +class ProgressBar(t.Generic[V]): + def __init__( + self, + iterable: t.Optional[t.Iterable[V]], + length: t.Optional[int] = None, + fill_char: str = "#", + empty_char: str = " ", + bar_template: str = "%(bar)s", + info_sep: str = " ", + show_eta: bool = True, + show_percent: t.Optional[bool] = None, + show_pos: bool = False, + item_show_func: t.Optional[t.Callable[[t.Optional[V]], t.Optional[str]]] = None, + label: t.Optional[str] = None, + file: t.Optional[t.TextIO] = None, + color: t.Optional[bool] = None, + update_min_steps: int = 1, + width: int = 30, + ) -> None: + self.fill_char = fill_char + self.empty_char = empty_char + self.bar_template = bar_template + self.info_sep = info_sep + self.show_eta = show_eta + self.show_percent = show_percent + self.show_pos = show_pos + self.item_show_func = item_show_func + self.label = label or "" + if file is None: + file = _default_text_stdout() + self.file = file + self.color = color + self.update_min_steps = update_min_steps + self._completed_intervals = 0 + self.width = width + self.autowidth = width == 0 + + if length is None: + from operator import length_hint + + length = length_hint(iterable, -1) + + if length == -1: + length = None + if iterable is None: + if length is None: + raise TypeError("iterable or length is required") + iterable = t.cast(t.Iterable[V], range(length)) + self.iter = iter(iterable) + self.length = length + self.pos = 0 + self.avg: t.List[float] = [] + self.start = self.last_eta = time.time() + self.eta_known = False + self.finished = False + self.max_width: t.Optional[int] = None + self.entered = False + self.current_item: t.Optional[V] = None + self.is_hidden = not isatty(self.file) + self._last_line: t.Optional[str] = None + + def __enter__(self) -> "ProgressBar": + self.entered = True + self.render_progress() + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + self.render_finish() + + def __iter__(self) -> t.Iterator[V]: + if not self.entered: + raise RuntimeError("You need to use progress bars in a with block.") + self.render_progress() + return self.generator() + + def __next__(self) -> V: + # Iteration is defined in terms of a generator function, + # returned by iter(self); use that to define next(). This works + # because `self.iter` is an iterable consumed by that generator, + # so it is re-entry safe. Calling `next(self.generator())` + # twice works and does "what you want". + return next(iter(self)) + + def render_finish(self) -> None: + if self.is_hidden: + return + self.file.write(AFTER_BAR) + self.file.flush() + + @property + def pct(self) -> float: + if self.finished: + return 1.0 + return min(self.pos / (float(self.length or 1) or 1), 1.0) + + @property + def time_per_iteration(self) -> float: + if not self.avg: + return 0.0 + return sum(self.avg) / float(len(self.avg)) + + @property + def eta(self) -> float: + if self.length is not None and not self.finished: + return self.time_per_iteration * (self.length - self.pos) + return 0.0 + + def format_eta(self) -> str: + if self.eta_known: + t = int(self.eta) + seconds = t % 60 + t //= 60 + minutes = t % 60 + t //= 60 + hours = t % 24 + t //= 24 + if t > 0: + return f"{t}d {hours:02}:{minutes:02}:{seconds:02}" + else: + return f"{hours:02}:{minutes:02}:{seconds:02}" + return "" + + def format_pos(self) -> str: + pos = str(self.pos) + if self.length is not None: + pos += f"/{self.length}" + return pos + + def format_pct(self) -> str: + return f"{int(self.pct * 100): 4}%"[1:] + + def format_bar(self) -> str: + if self.length is not None: + bar_length = int(self.pct * self.width) + bar = self.fill_char * bar_length + bar += self.empty_char * (self.width - bar_length) + elif self.finished: + bar = self.fill_char * self.width + else: + chars = list(self.empty_char * (self.width or 1)) + if self.time_per_iteration != 0: + chars[ + int( + (math.cos(self.pos * self.time_per_iteration) / 2.0 + 0.5) + * self.width + ) + ] = self.fill_char + bar = "".join(chars) + return bar + + def format_progress_line(self) -> str: + show_percent = self.show_percent + + info_bits = [] + if self.length is not None and show_percent is None: + show_percent = not self.show_pos + + if self.show_pos: + info_bits.append(self.format_pos()) + if show_percent: + info_bits.append(self.format_pct()) + if self.show_eta and self.eta_known and not self.finished: + info_bits.append(self.format_eta()) + if self.item_show_func is not None: + item_info = self.item_show_func(self.current_item) + if item_info is not None: + info_bits.append(item_info) + + return ( + self.bar_template + % { + "label": self.label, + "bar": self.format_bar(), + "info": self.info_sep.join(info_bits), + } + ).rstrip() + + def render_progress(self) -> None: + import shutil + + if self.is_hidden: + # Only output the label as it changes if the output is not a + # TTY. Use file=stderr if you expect to be piping stdout. + if self._last_line != self.label: + self._last_line = self.label + echo(self.label, file=self.file, color=self.color) + + return + + buf = [] + # Update width in case the terminal has been resized + if self.autowidth: + old_width = self.width + self.width = 0 + clutter_length = term_len(self.format_progress_line()) + new_width = max(0, shutil.get_terminal_size().columns - clutter_length) + if new_width < old_width: + buf.append(BEFORE_BAR) + buf.append(" " * self.max_width) # type: ignore + self.max_width = new_width + self.width = new_width + + clear_width = self.width + if self.max_width is not None: + clear_width = self.max_width + + buf.append(BEFORE_BAR) + line = self.format_progress_line() + line_len = term_len(line) + if self.max_width is None or self.max_width < line_len: + self.max_width = line_len + + buf.append(line) + buf.append(" " * (clear_width - line_len)) + line = "".join(buf) + # Render the line only if it changed. + + if line != self._last_line: + self._last_line = line + echo(line, file=self.file, color=self.color, nl=False) + self.file.flush() + + def make_step(self, n_steps: int) -> None: + self.pos += n_steps + if self.length is not None and self.pos >= self.length: + self.finished = True + + if (time.time() - self.last_eta) < 1.0: + return + + self.last_eta = time.time() + + # self.avg is a rolling list of length <= 7 of steps where steps are + # defined as time elapsed divided by the total progress through + # self.length. + if self.pos: + step = (time.time() - self.start) / self.pos + else: + step = time.time() - self.start + + self.avg = self.avg[-6:] + [step] + + self.eta_known = self.length is not None + + def update(self, n_steps: int, current_item: t.Optional[V] = None) -> None: + """Update the progress bar by advancing a specified number of + steps, and optionally set the ``current_item`` for this new + position. + + :param n_steps: Number of steps to advance. + :param current_item: Optional item to set as ``current_item`` + for the updated position. + + .. versionchanged:: 8.0 + Added the ``current_item`` optional parameter. + + .. versionchanged:: 8.0 + Only render when the number of steps meets the + ``update_min_steps`` threshold. + """ + if current_item is not None: + self.current_item = current_item + + self._completed_intervals += n_steps + + if self._completed_intervals >= self.update_min_steps: + self.make_step(self._completed_intervals) + self.render_progress() + self._completed_intervals = 0 + + def finish(self) -> None: + self.eta_known = False + self.current_item = None + self.finished = True + + def generator(self) -> t.Iterator[V]: + """Return a generator which yields the items added to the bar + during construction, and updates the progress bar *after* the + yielded block returns. + """ + # WARNING: the iterator interface for `ProgressBar` relies on + # this and only works because this is a simple generator which + # doesn't create or manage additional state. If this function + # changes, the impact should be evaluated both against + # `iter(bar)` and `next(bar)`. `next()` in particular may call + # `self.generator()` repeatedly, and this must remain safe in + # order for that interface to work. + if not self.entered: + raise RuntimeError("You need to use progress bars in a with block.") + + if self.is_hidden: + yield from self.iter + else: + for rv in self.iter: + self.current_item = rv + + # This allows show_item_func to be updated before the + # item is processed. Only trigger at the beginning of + # the update interval. + if self._completed_intervals == 0: + self.render_progress() + + yield rv + self.update(1) + + self.finish() + self.render_progress() + + +def pager(generator: t.Iterable[str], color: t.Optional[bool] = None) -> None: + """Decide what method to use for paging through text.""" + stdout = _default_text_stdout() + if not isatty(sys.stdin) or not isatty(stdout): + return _nullpager(stdout, generator, color) + pager_cmd = (os.environ.get("PAGER", None) or "").strip() + if pager_cmd: + if WIN: + return _tempfilepager(generator, pager_cmd, color) + return _pipepager(generator, pager_cmd, color) + if os.environ.get("TERM") in ("dumb", "emacs"): + return _nullpager(stdout, generator, color) + if WIN or sys.platform.startswith("os2"): + return _tempfilepager(generator, "more <", color) + if hasattr(os, "system") and os.system("(less) 2>/dev/null") == 0: + return _pipepager(generator, "less", color) + + import tempfile + + fd, filename = tempfile.mkstemp() + os.close(fd) + try: + if hasattr(os, "system") and os.system(f'more "{filename}"') == 0: + return _pipepager(generator, "more", color) + return _nullpager(stdout, generator, color) + finally: + os.unlink(filename) + + +def _pipepager(generator: t.Iterable[str], cmd: str, color: t.Optional[bool]) -> None: + """Page through text by feeding it to another program. Invoking a + pager through this might support colors. + """ + import subprocess + + env = dict(os.environ) + + # If we're piping to less we might support colors under the + # condition that + cmd_detail = cmd.rsplit("/", 1)[-1].split() + if color is None and cmd_detail[0] == "less": + less_flags = f"{os.environ.get('LESS', '')}{' '.join(cmd_detail[1:])}" + if not less_flags: + env["LESS"] = "-R" + color = True + elif "r" in less_flags or "R" in less_flags: + color = True + + c = subprocess.Popen(cmd, shell=True, stdin=subprocess.PIPE, env=env) + stdin = t.cast(t.BinaryIO, c.stdin) + encoding = get_best_encoding(stdin) + try: + for text in generator: + if not color: + text = strip_ansi(text) + + stdin.write(text.encode(encoding, "replace")) + except (OSError, KeyboardInterrupt): + pass + else: + stdin.close() + + # Less doesn't respect ^C, but catches it for its own UI purposes (aborting + # search or other commands inside less). + # + # That means when the user hits ^C, the parent process (click) terminates, + # but less is still alive, paging the output and messing up the terminal. + # + # If the user wants to make the pager exit on ^C, they should set + # `LESS='-K'`. It's not our decision to make. + while True: + try: + c.wait() + except KeyboardInterrupt: + pass + else: + break + + +def _tempfilepager( + generator: t.Iterable[str], cmd: str, color: t.Optional[bool] +) -> None: + """Page through text by invoking a program on a temporary file.""" + import tempfile + + fd, filename = tempfile.mkstemp() + # TODO: This never terminates if the passed generator never terminates. + text = "".join(generator) + if not color: + text = strip_ansi(text) + encoding = get_best_encoding(sys.stdout) + with open_stream(filename, "wb")[0] as f: + f.write(text.encode(encoding)) + try: + os.system(f'{cmd} "{filename}"') + finally: + os.close(fd) + os.unlink(filename) + + +def _nullpager( + stream: t.TextIO, generator: t.Iterable[str], color: t.Optional[bool] +) -> None: + """Simply print unformatted text. This is the ultimate fallback.""" + for text in generator: + if not color: + text = strip_ansi(text) + stream.write(text) + + +class Editor: + def __init__( + self, + editor: t.Optional[str] = None, + env: t.Optional[t.Mapping[str, str]] = None, + require_save: bool = True, + extension: str = ".txt", + ) -> None: + self.editor = editor + self.env = env + self.require_save = require_save + self.extension = extension + + def get_editor(self) -> str: + if self.editor is not None: + return self.editor + for key in "VISUAL", "EDITOR": + rv = os.environ.get(key) + if rv: + return rv + if WIN: + return "notepad" + for editor in "sensible-editor", "vim", "nano": + if os.system(f"which {editor} >/dev/null 2>&1") == 0: + return editor + return "vi" + + def edit_file(self, filename: str) -> None: + import subprocess + + editor = self.get_editor() + environ: t.Optional[t.Dict[str, str]] = None + + if self.env: + environ = os.environ.copy() + environ.update(self.env) + + try: + c = subprocess.Popen(f'{editor} "{filename}"', env=environ, shell=True) + exit_code = c.wait() + if exit_code != 0: + raise ClickException( + _("{editor}: Editing failed").format(editor=editor) + ) + except OSError as e: + raise ClickException( + _("{editor}: Editing failed: {e}").format(editor=editor, e=e) + ) from e + + def edit(self, text: t.Optional[t.AnyStr]) -> t.Optional[t.AnyStr]: + import tempfile + + if not text: + data = b"" + elif isinstance(text, (bytes, bytearray)): + data = text + else: + if text and not text.endswith("\n"): + text += "\n" + + if WIN: + data = text.replace("\n", "\r\n").encode("utf-8-sig") + else: + data = text.encode("utf-8") + + fd, name = tempfile.mkstemp(prefix="editor-", suffix=self.extension) + f: t.BinaryIO + + try: + with os.fdopen(fd, "wb") as f: + f.write(data) + + # If the filesystem resolution is 1 second, like Mac OS + # 10.12 Extended, or 2 seconds, like FAT32, and the editor + # closes very fast, require_save can fail. Set the modified + # time to be 2 seconds in the past to work around this. + os.utime(name, (os.path.getatime(name), os.path.getmtime(name) - 2)) + # Depending on the resolution, the exact value might not be + # recorded, so get the new recorded value. + timestamp = os.path.getmtime(name) + + self.edit_file(name) + + if self.require_save and os.path.getmtime(name) == timestamp: + return None + + with open(name, "rb") as f: + rv = f.read() + + if isinstance(text, (bytes, bytearray)): + return rv + + return rv.decode("utf-8-sig").replace("\r\n", "\n") # type: ignore + finally: + os.unlink(name) + + +def open_url(url: str, wait: bool = False, locate: bool = False) -> int: + import subprocess + + def _unquote_file(url: str) -> str: + from urllib.parse import unquote + + if url.startswith("file://"): + url = unquote(url[7:]) + + return url + + if sys.platform == "darwin": + args = ["open"] + if wait: + args.append("-W") + if locate: + args.append("-R") + args.append(_unquote_file(url)) + null = open("/dev/null", "w") + try: + return subprocess.Popen(args, stderr=null).wait() + finally: + null.close() + elif WIN: + if locate: + url = _unquote_file(url.replace('"', "")) + args = f'explorer /select,"{url}"' + else: + url = url.replace('"', "") + wait_str = "/WAIT" if wait else "" + args = f'start {wait_str} "" "{url}"' + return os.system(args) + elif CYGWIN: + if locate: + url = os.path.dirname(_unquote_file(url).replace('"', "")) + args = f'cygstart "{url}"' + else: + url = url.replace('"', "") + wait_str = "-w" if wait else "" + args = f'cygstart {wait_str} "{url}"' + return os.system(args) + + try: + if locate: + url = os.path.dirname(_unquote_file(url)) or "." + else: + url = _unquote_file(url) + c = subprocess.Popen(["xdg-open", url]) + if wait: + return c.wait() + return 0 + except OSError: + if url.startswith(("http://", "https://")) and not locate and not wait: + import webbrowser + + webbrowser.open(url) + return 0 + return 1 + + +def _translate_ch_to_exc(ch: str) -> t.Optional[BaseException]: + if ch == "\x03": + raise KeyboardInterrupt() + + if ch == "\x04" and not WIN: # Unix-like, Ctrl+D + raise EOFError() + + if ch == "\x1a" and WIN: # Windows, Ctrl+Z + raise EOFError() + + return None + + +if WIN: + import msvcrt + + @contextlib.contextmanager + def raw_terminal() -> t.Iterator[int]: + yield -1 + + def getchar(echo: bool) -> str: + # The function `getch` will return a bytes object corresponding to + # the pressed character. Since Windows 10 build 1803, it will also + # return \x00 when called a second time after pressing a regular key. + # + # `getwch` does not share this probably-bugged behavior. Moreover, it + # returns a Unicode object by default, which is what we want. + # + # Either of these functions will return \x00 or \xe0 to indicate + # a special key, and you need to call the same function again to get + # the "rest" of the code. The fun part is that \u00e0 is + # "latin small letter a with grave", so if you type that on a French + # keyboard, you _also_ get a \xe0. + # E.g., consider the Up arrow. This returns \xe0 and then \x48. The + # resulting Unicode string reads as "a with grave" + "capital H". + # This is indistinguishable from when the user actually types + # "a with grave" and then "capital H". + # + # When \xe0 is returned, we assume it's part of a special-key sequence + # and call `getwch` again, but that means that when the user types + # the \u00e0 character, `getchar` doesn't return until a second + # character is typed. + # The alternative is returning immediately, but that would mess up + # cross-platform handling of arrow keys and others that start with + # \xe0. Another option is using `getch`, but then we can't reliably + # read non-ASCII characters, because return values of `getch` are + # limited to the current 8-bit codepage. + # + # Anyway, Click doesn't claim to do this Right(tm), and using `getwch` + # is doing the right thing in more situations than with `getch`. + func: t.Callable[[], str] + + if echo: + func = msvcrt.getwche # type: ignore + else: + func = msvcrt.getwch # type: ignore + + rv = func() + + if rv in ("\x00", "\xe0"): + # \x00 and \xe0 are control characters that indicate special key, + # see above. + rv += func() + + _translate_ch_to_exc(rv) + return rv + + +else: + import tty + import termios + + @contextlib.contextmanager + def raw_terminal() -> t.Iterator[int]: + f: t.Optional[t.TextIO] + fd: int + + if not isatty(sys.stdin): + f = open("/dev/tty") + fd = f.fileno() + else: + fd = sys.stdin.fileno() + f = None + + try: + old_settings = termios.tcgetattr(fd) + + try: + tty.setraw(fd) + yield fd + finally: + termios.tcsetattr(fd, termios.TCSADRAIN, old_settings) + sys.stdout.flush() + + if f is not None: + f.close() + except termios.error: + pass + + def getchar(echo: bool) -> str: + with raw_terminal() as fd: + ch = os.read(fd, 32).decode(get_best_encoding(sys.stdin), "replace") + + if echo and isatty(sys.stdout): + sys.stdout.write(ch) + + _translate_ch_to_exc(ch) + return ch diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_textwrap.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_textwrap.py new file mode 100644 index 00000000..b47dcbd4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_textwrap.py @@ -0,0 +1,49 @@ +import textwrap +import typing as t +from contextlib import contextmanager + + +class TextWrapper(textwrap.TextWrapper): + def _handle_long_word( + self, + reversed_chunks: t.List[str], + cur_line: t.List[str], + cur_len: int, + width: int, + ) -> None: + space_left = max(width - cur_len, 1) + + if self.break_long_words: + last = reversed_chunks[-1] + cut = last[:space_left] + res = last[space_left:] + cur_line.append(cut) + reversed_chunks[-1] = res + elif not cur_line: + cur_line.append(reversed_chunks.pop()) + + @contextmanager + def extra_indent(self, indent: str) -> t.Iterator[None]: + old_initial_indent = self.initial_indent + old_subsequent_indent = self.subsequent_indent + self.initial_indent += indent + self.subsequent_indent += indent + + try: + yield + finally: + self.initial_indent = old_initial_indent + self.subsequent_indent = old_subsequent_indent + + def indent_only(self, text: str) -> str: + rv = [] + + for idx, line in enumerate(text.splitlines()): + indent = self.initial_indent + + if idx > 0: + indent = self.subsequent_indent + + rv.append(f"{indent}{line}") + + return "\n".join(rv) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_unicodefun.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_unicodefun.py new file mode 100644 index 00000000..9cb30c38 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_unicodefun.py @@ -0,0 +1,100 @@ +import codecs +import os +from gettext import gettext as _ + + +def _verify_python_env() -> None: + """Ensures that the environment is good for Unicode.""" + try: + from locale import getpreferredencoding + + fs_enc = codecs.lookup(getpreferredencoding()).name + except Exception: + fs_enc = "ascii" + + if fs_enc != "ascii": + return + + extra = [ + _( + "Click will abort further execution because Python was" + " configured to use ASCII as encoding for the environment." + " Consult https://click.palletsprojects.com/unicode-support/" + " for mitigation steps." + ) + ] + + if os.name == "posix": + import subprocess + + try: + rv = subprocess.Popen( + ["locale", "-a"], + stdout=subprocess.PIPE, + stderr=subprocess.PIPE, + encoding="ascii", + errors="replace", + ).communicate()[0] + except OSError: + rv = "" + + good_locales = set() + has_c_utf8 = False + + for line in rv.splitlines(): + locale = line.strip() + + if locale.lower().endswith((".utf-8", ".utf8")): + good_locales.add(locale) + + if locale.lower() in ("c.utf8", "c.utf-8"): + has_c_utf8 = True + + if not good_locales: + extra.append( + _( + "Additional information: on this system no suitable" + " UTF-8 locales were discovered. This most likely" + " requires resolving by reconfiguring the locale" + " system." + ) + ) + elif has_c_utf8: + extra.append( + _( + "This system supports the C.UTF-8 locale which is" + " recommended. You might be able to resolve your" + " issue by exporting the following environment" + " variables:" + ) + ) + extra.append(" export LC_ALL=C.UTF-8\n export LANG=C.UTF-8") + else: + extra.append( + _( + "This system lists some UTF-8 supporting locales" + " that you can pick from. The following suitable" + " locales were discovered: {locales}" + ).format(locales=", ".join(sorted(good_locales))) + ) + + bad_locale = None + + for env_locale in os.environ.get("LC_ALL"), os.environ.get("LANG"): + if env_locale and env_locale.lower().endswith((".utf-8", ".utf8")): + bad_locale = env_locale + + if env_locale is not None: + break + + if bad_locale is not None: + extra.append( + _( + "Click discovered that you exported a UTF-8 locale" + " but the locale system could not pick up from it" + " because it does not exist. The exported locale is" + " {locale!r} but it is not supported." + ).format(locale=bad_locale) + ) + + raise RuntimeError("\n\n".join(extra)) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_winconsole.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_winconsole.py new file mode 100644 index 00000000..6b20df31 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/_winconsole.py @@ -0,0 +1,279 @@ +# This module is based on the excellent work by Adam BartoÅ¡ who +# provided a lot of what went into the implementation here in +# the discussion to issue1602 in the Python bug tracker. +# +# There are some general differences in regards to how this works +# compared to the original patches as we do not need to patch +# the entire interpreter but just work in our little world of +# echo and prompt. +import io +import sys +import time +import typing as t +from ctypes import byref +from ctypes import c_char +from ctypes import c_char_p +from ctypes import c_int +from ctypes import c_ssize_t +from ctypes import c_ulong +from ctypes import c_void_p +from ctypes import POINTER +from ctypes import py_object +from ctypes import Structure +from ctypes.wintypes import DWORD +from ctypes.wintypes import HANDLE +from ctypes.wintypes import LPCWSTR +from ctypes.wintypes import LPWSTR + +from ._compat import _NonClosingTextIOWrapper + +assert sys.platform == "win32" +import msvcrt # noqa: E402 +from ctypes import windll # noqa: E402 +from ctypes import WINFUNCTYPE # noqa: E402 + +c_ssize_p = POINTER(c_ssize_t) + +kernel32 = windll.kernel32 +GetStdHandle = kernel32.GetStdHandle +ReadConsoleW = kernel32.ReadConsoleW +WriteConsoleW = kernel32.WriteConsoleW +GetConsoleMode = kernel32.GetConsoleMode +GetLastError = kernel32.GetLastError +GetCommandLineW = WINFUNCTYPE(LPWSTR)(("GetCommandLineW", windll.kernel32)) +CommandLineToArgvW = WINFUNCTYPE(POINTER(LPWSTR), LPCWSTR, POINTER(c_int))( + ("CommandLineToArgvW", windll.shell32) +) +LocalFree = WINFUNCTYPE(c_void_p, c_void_p)(("LocalFree", windll.kernel32)) + +STDIN_HANDLE = GetStdHandle(-10) +STDOUT_HANDLE = GetStdHandle(-11) +STDERR_HANDLE = GetStdHandle(-12) + +PyBUF_SIMPLE = 0 +PyBUF_WRITABLE = 1 + +ERROR_SUCCESS = 0 +ERROR_NOT_ENOUGH_MEMORY = 8 +ERROR_OPERATION_ABORTED = 995 + +STDIN_FILENO = 0 +STDOUT_FILENO = 1 +STDERR_FILENO = 2 + +EOF = b"\x1a" +MAX_BYTES_WRITTEN = 32767 + +try: + from ctypes import pythonapi +except ImportError: + # On PyPy we cannot get buffers so our ability to operate here is + # severely limited. + get_buffer = None +else: + + class Py_buffer(Structure): + _fields_ = [ + ("buf", c_void_p), + ("obj", py_object), + ("len", c_ssize_t), + ("itemsize", c_ssize_t), + ("readonly", c_int), + ("ndim", c_int), + ("format", c_char_p), + ("shape", c_ssize_p), + ("strides", c_ssize_p), + ("suboffsets", c_ssize_p), + ("internal", c_void_p), + ] + + PyObject_GetBuffer = pythonapi.PyObject_GetBuffer + PyBuffer_Release = pythonapi.PyBuffer_Release + + def get_buffer(obj, writable=False): + buf = Py_buffer() + flags = PyBUF_WRITABLE if writable else PyBUF_SIMPLE + PyObject_GetBuffer(py_object(obj), byref(buf), flags) + + try: + buffer_type = c_char * buf.len + return buffer_type.from_address(buf.buf) + finally: + PyBuffer_Release(byref(buf)) + + +class _WindowsConsoleRawIOBase(io.RawIOBase): + def __init__(self, handle): + self.handle = handle + + def isatty(self): + super().isatty() + return True + + +class _WindowsConsoleReader(_WindowsConsoleRawIOBase): + def readable(self): + return True + + def readinto(self, b): + bytes_to_be_read = len(b) + if not bytes_to_be_read: + return 0 + elif bytes_to_be_read % 2: + raise ValueError( + "cannot read odd number of bytes from UTF-16-LE encoded console" + ) + + buffer = get_buffer(b, writable=True) + code_units_to_be_read = bytes_to_be_read // 2 + code_units_read = c_ulong() + + rv = ReadConsoleW( + HANDLE(self.handle), + buffer, + code_units_to_be_read, + byref(code_units_read), + None, + ) + if GetLastError() == ERROR_OPERATION_ABORTED: + # wait for KeyboardInterrupt + time.sleep(0.1) + if not rv: + raise OSError(f"Windows error: {GetLastError()}") + + if buffer[0] == EOF: + return 0 + return 2 * code_units_read.value + + +class _WindowsConsoleWriter(_WindowsConsoleRawIOBase): + def writable(self): + return True + + @staticmethod + def _get_error_message(errno): + if errno == ERROR_SUCCESS: + return "ERROR_SUCCESS" + elif errno == ERROR_NOT_ENOUGH_MEMORY: + return "ERROR_NOT_ENOUGH_MEMORY" + return f"Windows error {errno}" + + def write(self, b): + bytes_to_be_written = len(b) + buf = get_buffer(b) + code_units_to_be_written = min(bytes_to_be_written, MAX_BYTES_WRITTEN) // 2 + code_units_written = c_ulong() + + WriteConsoleW( + HANDLE(self.handle), + buf, + code_units_to_be_written, + byref(code_units_written), + None, + ) + bytes_written = 2 * code_units_written.value + + if bytes_written == 0 and bytes_to_be_written > 0: + raise OSError(self._get_error_message(GetLastError())) + return bytes_written + + +class ConsoleStream: + def __init__(self, text_stream: t.TextIO, byte_stream: t.BinaryIO) -> None: + self._text_stream = text_stream + self.buffer = byte_stream + + @property + def name(self) -> str: + return self.buffer.name + + def write(self, x: t.AnyStr) -> int: + if isinstance(x, str): + return self._text_stream.write(x) + try: + self.flush() + except Exception: + pass + return self.buffer.write(x) + + def writelines(self, lines: t.Iterable[t.AnyStr]) -> None: + for line in lines: + self.write(line) + + def __getattr__(self, name: str) -> t.Any: + return getattr(self._text_stream, name) + + def isatty(self) -> bool: + return self.buffer.isatty() + + def __repr__(self): + return f"" + + +def _get_text_stdin(buffer_stream: t.BinaryIO) -> t.TextIO: + text_stream = _NonClosingTextIOWrapper( + io.BufferedReader(_WindowsConsoleReader(STDIN_HANDLE)), + "utf-16-le", + "strict", + line_buffering=True, + ) + return t.cast(t.TextIO, ConsoleStream(text_stream, buffer_stream)) + + +def _get_text_stdout(buffer_stream: t.BinaryIO) -> t.TextIO: + text_stream = _NonClosingTextIOWrapper( + io.BufferedWriter(_WindowsConsoleWriter(STDOUT_HANDLE)), + "utf-16-le", + "strict", + line_buffering=True, + ) + return t.cast(t.TextIO, ConsoleStream(text_stream, buffer_stream)) + + +def _get_text_stderr(buffer_stream: t.BinaryIO) -> t.TextIO: + text_stream = _NonClosingTextIOWrapper( + io.BufferedWriter(_WindowsConsoleWriter(STDERR_HANDLE)), + "utf-16-le", + "strict", + line_buffering=True, + ) + return t.cast(t.TextIO, ConsoleStream(text_stream, buffer_stream)) + + +_stream_factories: t.Mapping[int, t.Callable[[t.BinaryIO], t.TextIO]] = { + 0: _get_text_stdin, + 1: _get_text_stdout, + 2: _get_text_stderr, +} + + +def _is_console(f: t.TextIO) -> bool: + if not hasattr(f, "fileno"): + return False + + try: + fileno = f.fileno() + except (OSError, io.UnsupportedOperation): + return False + + handle = msvcrt.get_osfhandle(fileno) + return bool(GetConsoleMode(handle, byref(DWORD()))) + + +def _get_windows_console_stream( + f: t.TextIO, encoding: t.Optional[str], errors: t.Optional[str] +) -> t.Optional[t.TextIO]: + if ( + get_buffer is not None + and encoding in {"utf-16-le", None} + and errors in {"strict", None} + and _is_console(f) + ): + func = _stream_factories.get(f.fileno()) + if func is not None: + b = getattr(f, "buffer", None) + + if b is None: + return None + + return func(b) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/core.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/core.py new file mode 100644 index 00000000..f2263544 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/core.py @@ -0,0 +1,2953 @@ +import enum +import errno +import os +import sys +import typing +import typing as t +from collections import abc +from contextlib import contextmanager +from contextlib import ExitStack +from functools import partial +from functools import update_wrapper +from gettext import gettext as _ +from gettext import ngettext +from itertools import repeat + +from . import types +from ._unicodefun import _verify_python_env +from .exceptions import Abort +from .exceptions import BadParameter +from .exceptions import ClickException +from .exceptions import Exit +from .exceptions import MissingParameter +from .exceptions import UsageError +from .formatting import HelpFormatter +from .formatting import join_options +from .globals import pop_context +from .globals import push_context +from .parser import _flag_needs_value +from .parser import OptionParser +from .parser import split_opt +from .termui import confirm +from .termui import prompt +from .termui import style +from .utils import _detect_program_name +from .utils import _expand_args +from .utils import echo +from .utils import make_default_short_help +from .utils import make_str +from .utils import PacifyFlushWrapper + +if t.TYPE_CHECKING: + import typing_extensions as te + from .shell_completion import CompletionItem + +F = t.TypeVar("F", bound=t.Callable[..., t.Any]) +V = t.TypeVar("V") + + +def _complete_visible_commands( + ctx: "Context", incomplete: str +) -> t.Iterator[t.Tuple[str, "Command"]]: + """List all the subcommands of a group that start with the + incomplete value and aren't hidden. + + :param ctx: Invocation context for the group. + :param incomplete: Value being completed. May be empty. + """ + multi = t.cast(MultiCommand, ctx.command) + + for name in multi.list_commands(ctx): + if name.startswith(incomplete): + command = multi.get_command(ctx, name) + + if command is not None and not command.hidden: + yield name, command + + +def _check_multicommand( + base_command: "MultiCommand", cmd_name: str, cmd: "Command", register: bool = False +) -> None: + if not base_command.chain or not isinstance(cmd, MultiCommand): + return + if register: + hint = ( + "It is not possible to add multi commands as children to" + " another multi command that is in chain mode." + ) + else: + hint = ( + "Found a multi command as subcommand to a multi command" + " that is in chain mode. This is not supported." + ) + raise RuntimeError( + f"{hint}. Command {base_command.name!r} is set to chain and" + f" {cmd_name!r} was added as a subcommand but it in itself is a" + f" multi command. ({cmd_name!r} is a {type(cmd).__name__}" + f" within a chained {type(base_command).__name__} named" + f" {base_command.name!r})." + ) + + +def batch(iterable: t.Iterable[V], batch_size: int) -> t.List[t.Tuple[V, ...]]: + return list(zip(*repeat(iter(iterable), batch_size))) + + +@contextmanager +def augment_usage_errors( + ctx: "Context", param: t.Optional["Parameter"] = None +) -> t.Iterator[None]: + """Context manager that attaches extra information to exceptions.""" + try: + yield + except BadParameter as e: + if e.ctx is None: + e.ctx = ctx + if param is not None and e.param is None: + e.param = param + raise + except UsageError as e: + if e.ctx is None: + e.ctx = ctx + raise + + +def iter_params_for_processing( + invocation_order: t.Sequence["Parameter"], + declaration_order: t.Sequence["Parameter"], +) -> t.List["Parameter"]: + """Given a sequence of parameters in the order as should be considered + for processing and an iterable of parameters that exist, this returns + a list in the correct order as they should be processed. + """ + + def sort_key(item: "Parameter") -> t.Tuple[bool, float]: + try: + idx: float = invocation_order.index(item) + except ValueError: + idx = float("inf") + + return not item.is_eager, idx + + return sorted(declaration_order, key=sort_key) + + +class ParameterSource(enum.Enum): + """This is an :class:`~enum.Enum` that indicates the source of a + parameter's value. + + Use :meth:`click.Context.get_parameter_source` to get the + source for a parameter by name. + + .. versionchanged:: 8.0 + Use :class:`~enum.Enum` and drop the ``validate`` method. + + .. versionchanged:: 8.0 + Added the ``PROMPT`` value. + """ + + COMMANDLINE = enum.auto() + """The value was provided by the command line args.""" + ENVIRONMENT = enum.auto() + """The value was provided with an environment variable.""" + DEFAULT = enum.auto() + """Used the default specified by the parameter.""" + DEFAULT_MAP = enum.auto() + """Used a default provided by :attr:`Context.default_map`.""" + PROMPT = enum.auto() + """Used a prompt to confirm a default or provide a value.""" + + +class Context: + """The context is a special internal object that holds state relevant + for the script execution at every single level. It's normally invisible + to commands unless they opt-in to getting access to it. + + The context is useful as it can pass internal objects around and can + control special execution features such as reading data from + environment variables. + + A context can be used as context manager in which case it will call + :meth:`close` on teardown. + + :param command: the command class for this context. + :param parent: the parent context. + :param info_name: the info name for this invocation. Generally this + is the most descriptive name for the script or + command. For the toplevel script it is usually + the name of the script, for commands below it it's + the name of the script. + :param obj: an arbitrary object of user data. + :param auto_envvar_prefix: the prefix to use for automatic environment + variables. If this is `None` then reading + from environment variables is disabled. This + does not affect manually set environment + variables which are always read. + :param default_map: a dictionary (like object) with default values + for parameters. + :param terminal_width: the width of the terminal. The default is + inherit from parent context. If no context + defines the terminal width then auto + detection will be applied. + :param max_content_width: the maximum width for content rendered by + Click (this currently only affects help + pages). This defaults to 80 characters if + not overridden. In other words: even if the + terminal is larger than that, Click will not + format things wider than 80 characters by + default. In addition to that, formatters might + add some safety mapping on the right. + :param resilient_parsing: if this flag is enabled then Click will + parse without any interactivity or callback + invocation. Default values will also be + ignored. This is useful for implementing + things such as completion support. + :param allow_extra_args: if this is set to `True` then extra arguments + at the end will not raise an error and will be + kept on the context. The default is to inherit + from the command. + :param allow_interspersed_args: if this is set to `False` then options + and arguments cannot be mixed. The + default is to inherit from the command. + :param ignore_unknown_options: instructs click to ignore options it does + not know and keeps them for later + processing. + :param help_option_names: optionally a list of strings that define how + the default help parameter is named. The + default is ``['--help']``. + :param token_normalize_func: an optional function that is used to + normalize tokens (options, choices, + etc.). This for instance can be used to + implement case insensitive behavior. + :param color: controls if the terminal supports ANSI colors or not. The + default is autodetection. This is only needed if ANSI + codes are used in texts that Click prints which is by + default not the case. This for instance would affect + help output. + :param show_default: Show defaults for all options. If not set, + defaults to the value from a parent context. Overrides an + option's ``show_default`` argument. + + .. versionchanged:: 8.0 + The ``show_default`` parameter defaults to the value from the + parent context. + + .. versionchanged:: 7.1 + Added the ``show_default`` parameter. + + .. versionchanged:: 4.0 + Added the ``color``, ``ignore_unknown_options``, and + ``max_content_width`` parameters. + + .. versionchanged:: 3.0 + Added the ``allow_extra_args`` and ``allow_interspersed_args`` + parameters. + + .. versionchanged:: 2.0 + Added the ``resilient_parsing``, ``help_option_names``, and + ``token_normalize_func`` parameters. + """ + + #: The formatter class to create with :meth:`make_formatter`. + #: + #: .. versionadded:: 8.0 + formatter_class: t.Type["HelpFormatter"] = HelpFormatter + + def __init__( + self, + command: "Command", + parent: t.Optional["Context"] = None, + info_name: t.Optional[str] = None, + obj: t.Optional[t.Any] = None, + auto_envvar_prefix: t.Optional[str] = None, + default_map: t.Optional[t.Dict[str, t.Any]] = None, + terminal_width: t.Optional[int] = None, + max_content_width: t.Optional[int] = None, + resilient_parsing: bool = False, + allow_extra_args: t.Optional[bool] = None, + allow_interspersed_args: t.Optional[bool] = None, + ignore_unknown_options: t.Optional[bool] = None, + help_option_names: t.Optional[t.List[str]] = None, + token_normalize_func: t.Optional[t.Callable[[str], str]] = None, + color: t.Optional[bool] = None, + show_default: t.Optional[bool] = None, + ) -> None: + #: the parent context or `None` if none exists. + self.parent = parent + #: the :class:`Command` for this context. + self.command = command + #: the descriptive information name + self.info_name = info_name + #: Map of parameter names to their parsed values. Parameters + #: with ``expose_value=False`` are not stored. + self.params: t.Dict[str, t.Any] = {} + #: the leftover arguments. + self.args: t.List[str] = [] + #: protected arguments. These are arguments that are prepended + #: to `args` when certain parsing scenarios are encountered but + #: must be never propagated to another arguments. This is used + #: to implement nested parsing. + self.protected_args: t.List[str] = [] + + if obj is None and parent is not None: + obj = parent.obj + + #: the user object stored. + self.obj: t.Any = obj + self._meta: t.Dict[str, t.Any] = getattr(parent, "meta", {}) + + #: A dictionary (-like object) with defaults for parameters. + if ( + default_map is None + and info_name is not None + and parent is not None + and parent.default_map is not None + ): + default_map = parent.default_map.get(info_name) + + self.default_map: t.Optional[t.Dict[str, t.Any]] = default_map + + #: This flag indicates if a subcommand is going to be executed. A + #: group callback can use this information to figure out if it's + #: being executed directly or because the execution flow passes + #: onwards to a subcommand. By default it's None, but it can be + #: the name of the subcommand to execute. + #: + #: If chaining is enabled this will be set to ``'*'`` in case + #: any commands are executed. It is however not possible to + #: figure out which ones. If you require this knowledge you + #: should use a :func:`result_callback`. + self.invoked_subcommand: t.Optional[str] = None + + if terminal_width is None and parent is not None: + terminal_width = parent.terminal_width + + #: The width of the terminal (None is autodetection). + self.terminal_width: t.Optional[int] = terminal_width + + if max_content_width is None and parent is not None: + max_content_width = parent.max_content_width + + #: The maximum width of formatted content (None implies a sensible + #: default which is 80 for most things). + self.max_content_width: t.Optional[int] = max_content_width + + if allow_extra_args is None: + allow_extra_args = command.allow_extra_args + + #: Indicates if the context allows extra args or if it should + #: fail on parsing. + #: + #: .. versionadded:: 3.0 + self.allow_extra_args = allow_extra_args + + if allow_interspersed_args is None: + allow_interspersed_args = command.allow_interspersed_args + + #: Indicates if the context allows mixing of arguments and + #: options or not. + #: + #: .. versionadded:: 3.0 + self.allow_interspersed_args: bool = allow_interspersed_args + + if ignore_unknown_options is None: + ignore_unknown_options = command.ignore_unknown_options + + #: Instructs click to ignore options that a command does not + #: understand and will store it on the context for later + #: processing. This is primarily useful for situations where you + #: want to call into external programs. Generally this pattern is + #: strongly discouraged because it's not possibly to losslessly + #: forward all arguments. + #: + #: .. versionadded:: 4.0 + self.ignore_unknown_options: bool = ignore_unknown_options + + if help_option_names is None: + if parent is not None: + help_option_names = parent.help_option_names + else: + help_option_names = ["--help"] + + #: The names for the help options. + self.help_option_names: t.List[str] = help_option_names + + if token_normalize_func is None and parent is not None: + token_normalize_func = parent.token_normalize_func + + #: An optional normalization function for tokens. This is + #: options, choices, commands etc. + self.token_normalize_func: t.Optional[ + t.Callable[[str], str] + ] = token_normalize_func + + #: Indicates if resilient parsing is enabled. In that case Click + #: will do its best to not cause any failures and default values + #: will be ignored. Useful for completion. + self.resilient_parsing: bool = resilient_parsing + + # If there is no envvar prefix yet, but the parent has one and + # the command on this level has a name, we can expand the envvar + # prefix automatically. + if auto_envvar_prefix is None: + if ( + parent is not None + and parent.auto_envvar_prefix is not None + and self.info_name is not None + ): + auto_envvar_prefix = ( + f"{parent.auto_envvar_prefix}_{self.info_name.upper()}" + ) + else: + auto_envvar_prefix = auto_envvar_prefix.upper() + + if auto_envvar_prefix is not None: + auto_envvar_prefix = auto_envvar_prefix.replace("-", "_") + + self.auto_envvar_prefix: t.Optional[str] = auto_envvar_prefix + + if color is None and parent is not None: + color = parent.color + + #: Controls if styling output is wanted or not. + self.color: t.Optional[bool] = color + + if show_default is None and parent is not None: + show_default = parent.show_default + + #: Show option default values when formatting help text. + self.show_default: t.Optional[bool] = show_default + + self._close_callbacks: t.List[t.Callable[[], t.Any]] = [] + self._depth = 0 + self._parameter_source: t.Dict[str, ParameterSource] = {} + self._exit_stack = ExitStack() + + def to_info_dict(self) -> t.Dict[str, t.Any]: + """Gather information that could be useful for a tool generating + user-facing documentation. This traverses the entire CLI + structure. + + .. code-block:: python + + with Context(cli) as ctx: + info = ctx.to_info_dict() + + .. versionadded:: 8.0 + """ + return { + "command": self.command.to_info_dict(self), + "info_name": self.info_name, + "allow_extra_args": self.allow_extra_args, + "allow_interspersed_args": self.allow_interspersed_args, + "ignore_unknown_options": self.ignore_unknown_options, + "auto_envvar_prefix": self.auto_envvar_prefix, + } + + def __enter__(self) -> "Context": + self._depth += 1 + push_context(self) + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + self._depth -= 1 + if self._depth == 0: + self.close() + pop_context() + + @contextmanager + def scope(self, cleanup: bool = True) -> t.Iterator["Context"]: + """This helper method can be used with the context object to promote + it to the current thread local (see :func:`get_current_context`). + The default behavior of this is to invoke the cleanup functions which + can be disabled by setting `cleanup` to `False`. The cleanup + functions are typically used for things such as closing file handles. + + If the cleanup is intended the context object can also be directly + used as a context manager. + + Example usage:: + + with ctx.scope(): + assert get_current_context() is ctx + + This is equivalent:: + + with ctx: + assert get_current_context() is ctx + + .. versionadded:: 5.0 + + :param cleanup: controls if the cleanup functions should be run or + not. The default is to run these functions. In + some situations the context only wants to be + temporarily pushed in which case this can be disabled. + Nested pushes automatically defer the cleanup. + """ + if not cleanup: + self._depth += 1 + try: + with self as rv: + yield rv + finally: + if not cleanup: + self._depth -= 1 + + @property + def meta(self) -> t.Dict[str, t.Any]: + """This is a dictionary which is shared with all the contexts + that are nested. It exists so that click utilities can store some + state here if they need to. It is however the responsibility of + that code to manage this dictionary well. + + The keys are supposed to be unique dotted strings. For instance + module paths are a good choice for it. What is stored in there is + irrelevant for the operation of click. However what is important is + that code that places data here adheres to the general semantics of + the system. + + Example usage:: + + LANG_KEY = f'{__name__}.lang' + + def set_language(value): + ctx = get_current_context() + ctx.meta[LANG_KEY] = value + + def get_language(): + return get_current_context().meta.get(LANG_KEY, 'en_US') + + .. versionadded:: 5.0 + """ + return self._meta + + def make_formatter(self) -> HelpFormatter: + """Creates the :class:`~click.HelpFormatter` for the help and + usage output. + + To quickly customize the formatter class used without overriding + this method, set the :attr:`formatter_class` attribute. + + .. versionchanged:: 8.0 + Added the :attr:`formatter_class` attribute. + """ + return self.formatter_class( + width=self.terminal_width, max_width=self.max_content_width + ) + + def with_resource(self, context_manager: t.ContextManager[V]) -> V: + """Register a resource as if it were used in a ``with`` + statement. The resource will be cleaned up when the context is + popped. + + Uses :meth:`contextlib.ExitStack.enter_context`. It calls the + resource's ``__enter__()`` method and returns the result. When + the context is popped, it closes the stack, which calls the + resource's ``__exit__()`` method. + + To register a cleanup function for something that isn't a + context manager, use :meth:`call_on_close`. Or use something + from :mod:`contextlib` to turn it into a context manager first. + + .. code-block:: python + + @click.group() + @click.option("--name") + @click.pass_context + def cli(ctx): + ctx.obj = ctx.with_resource(connect_db(name)) + + :param context_manager: The context manager to enter. + :return: Whatever ``context_manager.__enter__()`` returns. + + .. versionadded:: 8.0 + """ + return self._exit_stack.enter_context(context_manager) + + def call_on_close(self, f: t.Callable[..., t.Any]) -> t.Callable[..., t.Any]: + """Register a function to be called when the context tears down. + + This can be used to close resources opened during the script + execution. Resources that support Python's context manager + protocol which would be used in a ``with`` statement should be + registered with :meth:`with_resource` instead. + + :param f: The function to execute on teardown. + """ + return self._exit_stack.callback(f) + + def close(self) -> None: + """Invoke all close callbacks registered with + :meth:`call_on_close`, and exit all context managers entered + with :meth:`with_resource`. + """ + self._exit_stack.close() + # In case the context is reused, create a new exit stack. + self._exit_stack = ExitStack() + + @property + def command_path(self) -> str: + """The computed command path. This is used for the ``usage`` + information on the help page. It's automatically created by + combining the info names of the chain of contexts to the root. + """ + rv = "" + if self.info_name is not None: + rv = self.info_name + if self.parent is not None: + parent_command_path = [self.parent.command_path] + + if isinstance(self.parent.command, Command): + for param in self.parent.command.get_params(self): + parent_command_path.extend(param.get_usage_pieces(self)) + + rv = f"{' '.join(parent_command_path)} {rv}" + return rv.lstrip() + + def find_root(self) -> "Context": + """Finds the outermost context.""" + node = self + while node.parent is not None: + node = node.parent + return node + + def find_object(self, object_type: t.Type[V]) -> t.Optional[V]: + """Finds the closest object of a given type.""" + node: t.Optional["Context"] = self + + while node is not None: + if isinstance(node.obj, object_type): + return node.obj + + node = node.parent + + return None + + def ensure_object(self, object_type: t.Type[V]) -> V: + """Like :meth:`find_object` but sets the innermost object to a + new instance of `object_type` if it does not exist. + """ + rv = self.find_object(object_type) + if rv is None: + self.obj = rv = object_type() + return rv + + @typing.overload + def lookup_default( + self, name: str, call: "te.Literal[True]" = True + ) -> t.Optional[t.Any]: + ... + + @typing.overload + def lookup_default( + self, name: str, call: "te.Literal[False]" = ... + ) -> t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]]: + ... + + def lookup_default(self, name: str, call: bool = True) -> t.Optional[t.Any]: + """Get the default for a parameter from :attr:`default_map`. + + :param name: Name of the parameter. + :param call: If the default is a callable, call it. Disable to + return the callable instead. + + .. versionchanged:: 8.0 + Added the ``call`` parameter. + """ + if self.default_map is not None: + value = self.default_map.get(name) + + if call and callable(value): + return value() + + return value + + return None + + def fail(self, message: str) -> "te.NoReturn": + """Aborts the execution of the program with a specific error + message. + + :param message: the error message to fail with. + """ + raise UsageError(message, self) + + def abort(self) -> "te.NoReturn": + """Aborts the script.""" + raise Abort() + + def exit(self, code: int = 0) -> "te.NoReturn": + """Exits the application with a given exit code.""" + raise Exit(code) + + def get_usage(self) -> str: + """Helper method to get formatted usage string for the current + context and command. + """ + return self.command.get_usage(self) + + def get_help(self) -> str: + """Helper method to get formatted help page for the current + context and command. + """ + return self.command.get_help(self) + + def _make_sub_context(self, command: "Command") -> "Context": + """Create a new context of the same type as this context, but + for a new command. + + :meta private: + """ + return type(self)(command, info_name=command.name, parent=self) + + def invoke( + __self, # noqa: B902 + __callback: t.Union["Command", t.Callable[..., t.Any]], + *args: t.Any, + **kwargs: t.Any, + ) -> t.Any: + """Invokes a command callback in exactly the way it expects. There + are two ways to invoke this method: + + 1. the first argument can be a callback and all other arguments and + keyword arguments are forwarded directly to the function. + 2. the first argument is a click command object. In that case all + arguments are forwarded as well but proper click parameters + (options and click arguments) must be keyword arguments and Click + will fill in defaults. + + Note that before Click 3.2 keyword arguments were not properly filled + in against the intention of this code and no context was created. For + more information about this change and why it was done in a bugfix + release see :ref:`upgrade-to-3.2`. + + .. versionchanged:: 8.0 + All ``kwargs`` are tracked in :attr:`params` so they will be + passed if :meth:`forward` is called at multiple levels. + """ + if isinstance(__callback, Command): + other_cmd = __callback + + if other_cmd.callback is None: + raise TypeError( + "The given command does not have a callback that can be invoked." + ) + else: + __callback = other_cmd.callback + + ctx = __self._make_sub_context(other_cmd) + + for param in other_cmd.params: + if param.name not in kwargs and param.expose_value: + kwargs[param.name] = param.type_cast_value( # type: ignore + ctx, param.get_default(ctx) + ) + + # Track all kwargs as params, so that forward() will pass + # them on in subsequent calls. + ctx.params.update(kwargs) + else: + ctx = __self + + with augment_usage_errors(__self): + with ctx: + return __callback(*args, **kwargs) + + def forward( + __self, __cmd: "Command", *args: t.Any, **kwargs: t.Any # noqa: B902 + ) -> t.Any: + """Similar to :meth:`invoke` but fills in default keyword + arguments from the current context if the other command expects + it. This cannot invoke callbacks directly, only other commands. + + .. versionchanged:: 8.0 + All ``kwargs`` are tracked in :attr:`params` so they will be + passed if ``forward`` is called at multiple levels. + """ + # Can only forward to other commands, not direct callbacks. + if not isinstance(__cmd, Command): + raise TypeError("Callback is not a command.") + + for param in __self.params: + if param not in kwargs: + kwargs[param] = __self.params[param] + + return __self.invoke(__cmd, *args, **kwargs) + + def set_parameter_source(self, name: str, source: ParameterSource) -> None: + """Set the source of a parameter. This indicates the location + from which the value of the parameter was obtained. + + :param name: The name of the parameter. + :param source: A member of :class:`~click.core.ParameterSource`. + """ + self._parameter_source[name] = source + + def get_parameter_source(self, name: str) -> t.Optional[ParameterSource]: + """Get the source of a parameter. This indicates the location + from which the value of the parameter was obtained. + + This can be useful for determining when a user specified a value + on the command line that is the same as the default value. It + will be :attr:`~click.core.ParameterSource.DEFAULT` only if the + value was actually taken from the default. + + :param name: The name of the parameter. + :rtype: ParameterSource + + .. versionchanged:: 8.0 + Returns ``None`` if the parameter was not provided from any + source. + """ + return self._parameter_source.get(name) + + +class BaseCommand: + """The base command implements the minimal API contract of commands. + Most code will never use this as it does not implement a lot of useful + functionality but it can act as the direct subclass of alternative + parsing methods that do not depend on the Click parser. + + For instance, this can be used to bridge Click and other systems like + argparse or docopt. + + Because base commands do not implement a lot of the API that other + parts of Click take for granted, they are not supported for all + operations. For instance, they cannot be used with the decorators + usually and they have no built-in callback system. + + .. versionchanged:: 2.0 + Added the `context_settings` parameter. + + :param name: the name of the command to use unless a group overrides it. + :param context_settings: an optional dictionary with defaults that are + passed to the context object. + """ + + #: The context class to create with :meth:`make_context`. + #: + #: .. versionadded:: 8.0 + context_class: t.Type[Context] = Context + #: the default for the :attr:`Context.allow_extra_args` flag. + allow_extra_args = False + #: the default for the :attr:`Context.allow_interspersed_args` flag. + allow_interspersed_args = True + #: the default for the :attr:`Context.ignore_unknown_options` flag. + ignore_unknown_options = False + + def __init__( + self, + name: t.Optional[str], + context_settings: t.Optional[t.Dict[str, t.Any]] = None, + ) -> None: + #: the name the command thinks it has. Upon registering a command + #: on a :class:`Group` the group will default the command name + #: with this information. You should instead use the + #: :class:`Context`\'s :attr:`~Context.info_name` attribute. + self.name = name + + if context_settings is None: + context_settings = {} + + #: an optional dictionary with defaults passed to the context. + self.context_settings: t.Dict[str, t.Any] = context_settings + + def to_info_dict(self, ctx: Context) -> t.Dict[str, t.Any]: + """Gather information that could be useful for a tool generating + user-facing documentation. This traverses the entire structure + below this command. + + Use :meth:`click.Context.to_info_dict` to traverse the entire + CLI structure. + + :param ctx: A :class:`Context` representing this command. + + .. versionadded:: 8.0 + """ + return {"name": self.name} + + def __repr__(self) -> str: + return f"<{self.__class__.__name__} {self.name}>" + + def get_usage(self, ctx: Context) -> str: + raise NotImplementedError("Base commands cannot get usage") + + def get_help(self, ctx: Context) -> str: + raise NotImplementedError("Base commands cannot get help") + + def make_context( + self, + info_name: t.Optional[str], + args: t.List[str], + parent: t.Optional[Context] = None, + **extra: t.Any, + ) -> Context: + """This function when given an info name and arguments will kick + off the parsing and create a new :class:`Context`. It does not + invoke the actual command callback though. + + To quickly customize the context class used without overriding + this method, set the :attr:`context_class` attribute. + + :param info_name: the info name for this invocation. Generally this + is the most descriptive name for the script or + command. For the toplevel script it's usually + the name of the script, for commands below it it's + the name of the command. + :param args: the arguments to parse as list of strings. + :param parent: the parent context if available. + :param extra: extra keyword arguments forwarded to the context + constructor. + + .. versionchanged:: 8.0 + Added the :attr:`context_class` attribute. + """ + for key, value in self.context_settings.items(): + if key not in extra: + extra[key] = value + + ctx = self.context_class( + self, info_name=info_name, parent=parent, **extra # type: ignore + ) + + with ctx.scope(cleanup=False): + self.parse_args(ctx, args) + return ctx + + def parse_args(self, ctx: Context, args: t.List[str]) -> t.List[str]: + """Given a context and a list of arguments this creates the parser + and parses the arguments, then modifies the context as necessary. + This is automatically invoked by :meth:`make_context`. + """ + raise NotImplementedError("Base commands do not know how to parse arguments.") + + def invoke(self, ctx: Context) -> t.Any: + """Given a context, this invokes the command. The default + implementation is raising a not implemented error. + """ + raise NotImplementedError("Base commands are not invokable by default") + + def shell_complete(self, ctx: Context, incomplete: str) -> t.List["CompletionItem"]: + """Return a list of completions for the incomplete value. Looks + at the names of chained multi-commands. + + Any command could be part of a chained multi-command, so sibling + commands are valid at any point during command completion. Other + command classes will return more completions. + + :param ctx: Invocation context for this command. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + results: t.List["CompletionItem"] = [] + + while ctx.parent is not None: + ctx = ctx.parent + + if isinstance(ctx.command, MultiCommand) and ctx.command.chain: + results.extend( + CompletionItem(name, help=command.get_short_help_str()) + for name, command in _complete_visible_commands(ctx, incomplete) + if name not in ctx.protected_args + ) + + return results + + @typing.overload + def main( + self, + args: t.Optional[t.Sequence[str]] = None, + prog_name: t.Optional[str] = None, + complete_var: t.Optional[str] = None, + standalone_mode: "te.Literal[True]" = True, + **extra: t.Any, + ) -> "te.NoReturn": + ... + + @typing.overload + def main( + self, + args: t.Optional[t.Sequence[str]] = None, + prog_name: t.Optional[str] = None, + complete_var: t.Optional[str] = None, + standalone_mode: bool = ..., + **extra: t.Any, + ) -> t.Any: + ... + + def main( + self, + args: t.Optional[t.Sequence[str]] = None, + prog_name: t.Optional[str] = None, + complete_var: t.Optional[str] = None, + standalone_mode: bool = True, + windows_expand_args: bool = True, + **extra: t.Any, + ) -> t.Any: + """This is the way to invoke a script with all the bells and + whistles as a command line application. This will always terminate + the application after a call. If this is not wanted, ``SystemExit`` + needs to be caught. + + This method is also available by directly calling the instance of + a :class:`Command`. + + :param args: the arguments that should be used for parsing. If not + provided, ``sys.argv[1:]`` is used. + :param prog_name: the program name that should be used. By default + the program name is constructed by taking the file + name from ``sys.argv[0]``. + :param complete_var: the environment variable that controls the + bash completion support. The default is + ``"__COMPLETE"`` with prog_name in + uppercase. + :param standalone_mode: the default behavior is to invoke the script + in standalone mode. Click will then + handle exceptions and convert them into + error messages and the function will never + return but shut down the interpreter. If + this is set to `False` they will be + propagated to the caller and the return + value of this function is the return value + of :meth:`invoke`. + :param windows_expand_args: Expand glob patterns, user dir, and + env vars in command line args on Windows. + :param extra: extra keyword arguments are forwarded to the context + constructor. See :class:`Context` for more information. + + .. versionchanged:: 8.0.1 + Added the ``windows_expand_args`` parameter to allow + disabling command line arg expansion on Windows. + + .. versionchanged:: 8.0 + When taking arguments from ``sys.argv`` on Windows, glob + patterns, user dir, and env vars are expanded. + + .. versionchanged:: 3.0 + Added the ``standalone_mode`` parameter. + """ + # Verify that the environment is configured correctly, or reject + # further execution to avoid a broken script. + _verify_python_env() + + if args is None: + args = sys.argv[1:] + + if os.name == "nt" and windows_expand_args: + args = _expand_args(args) + else: + args = list(args) + + if prog_name is None: + prog_name = _detect_program_name() + + # Process shell completion requests and exit early. + self._main_shell_completion(extra, prog_name, complete_var) + + try: + try: + with self.make_context(prog_name, args, **extra) as ctx: + rv = self.invoke(ctx) + if not standalone_mode: + return rv + # it's not safe to `ctx.exit(rv)` here! + # note that `rv` may actually contain data like "1" which + # has obvious effects + # more subtle case: `rv=[None, None]` can come out of + # chained commands which all returned `None` -- so it's not + # even always obvious that `rv` indicates success/failure + # by its truthiness/falsiness + ctx.exit() + except (EOFError, KeyboardInterrupt): + echo(file=sys.stderr) + raise Abort() from None + except ClickException as e: + if not standalone_mode: + raise + e.show() + sys.exit(e.exit_code) + except OSError as e: + if e.errno == errno.EPIPE: + sys.stdout = t.cast(t.TextIO, PacifyFlushWrapper(sys.stdout)) + sys.stderr = t.cast(t.TextIO, PacifyFlushWrapper(sys.stderr)) + sys.exit(1) + else: + raise + except Exit as e: + if standalone_mode: + sys.exit(e.exit_code) + else: + # in non-standalone mode, return the exit code + # note that this is only reached if `self.invoke` above raises + # an Exit explicitly -- thus bypassing the check there which + # would return its result + # the results of non-standalone execution may therefore be + # somewhat ambiguous: if there are codepaths which lead to + # `ctx.exit(1)` and to `return 1`, the caller won't be able to + # tell the difference between the two + return e.exit_code + except Abort: + if not standalone_mode: + raise + echo(_("Aborted!"), file=sys.stderr) + sys.exit(1) + + def _main_shell_completion( + self, + ctx_args: t.Dict[str, t.Any], + prog_name: str, + complete_var: t.Optional[str] = None, + ) -> None: + """Check if the shell is asking for tab completion, process + that, then exit early. Called from :meth:`main` before the + program is invoked. + + :param prog_name: Name of the executable in the shell. + :param complete_var: Name of the environment variable that holds + the completion instruction. Defaults to + ``_{PROG_NAME}_COMPLETE``. + """ + if complete_var is None: + complete_var = f"_{prog_name}_COMPLETE".replace("-", "_").upper() + + instruction = os.environ.get(complete_var) + + if not instruction: + return + + from .shell_completion import shell_complete + + rv = shell_complete(self, ctx_args, prog_name, complete_var, instruction) + sys.exit(rv) + + def __call__(self, *args: t.Any, **kwargs: t.Any) -> t.Any: + """Alias for :meth:`main`.""" + return self.main(*args, **kwargs) + + +class Command(BaseCommand): + """Commands are the basic building block of command line interfaces in + Click. A basic command handles command line parsing and might dispatch + more parsing to commands nested below it. + + .. versionchanged:: 2.0 + Added the `context_settings` parameter. + .. versionchanged:: 8.0 + Added repr showing the command name + .. versionchanged:: 7.1 + Added the `no_args_is_help` parameter. + + :param name: the name of the command to use unless a group overrides it. + :param context_settings: an optional dictionary with defaults that are + passed to the context object. + :param callback: the callback to invoke. This is optional. + :param params: the parameters to register with this command. This can + be either :class:`Option` or :class:`Argument` objects. + :param help: the help string to use for this command. + :param epilog: like the help string but it's printed at the end of the + help page after everything else. + :param short_help: the short help to use for this command. This is + shown on the command listing of the parent command. + :param add_help_option: by default each command registers a ``--help`` + option. This can be disabled by this parameter. + :param no_args_is_help: this controls what happens if no arguments are + provided. This option is disabled by default. + If enabled this will add ``--help`` as argument + if no arguments are passed + :param hidden: hide this command from help outputs. + + :param deprecated: issues a message indicating that + the command is deprecated. + """ + + def __init__( + self, + name: t.Optional[str], + context_settings: t.Optional[t.Dict[str, t.Any]] = None, + callback: t.Optional[t.Callable[..., t.Any]] = None, + params: t.Optional[t.List["Parameter"]] = None, + help: t.Optional[str] = None, + epilog: t.Optional[str] = None, + short_help: t.Optional[str] = None, + options_metavar: t.Optional[str] = "[OPTIONS]", + add_help_option: bool = True, + no_args_is_help: bool = False, + hidden: bool = False, + deprecated: bool = False, + ) -> None: + super().__init__(name, context_settings) + #: the callback to execute when the command fires. This might be + #: `None` in which case nothing happens. + self.callback = callback + #: the list of parameters for this command in the order they + #: should show up in the help page and execute. Eager parameters + #: will automatically be handled before non eager ones. + self.params: t.List["Parameter"] = params or [] + + # if a form feed (page break) is found in the help text, truncate help + # text to the content preceding the first form feed + if help and "\f" in help: + help = help.split("\f", 1)[0] + + self.help = help + self.epilog = epilog + self.options_metavar = options_metavar + self.short_help = short_help + self.add_help_option = add_help_option + self.no_args_is_help = no_args_is_help + self.hidden = hidden + self.deprecated = deprecated + + def to_info_dict(self, ctx: Context) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict(ctx) + info_dict.update( + params=[param.to_info_dict() for param in self.get_params(ctx)], + help=self.help, + epilog=self.epilog, + short_help=self.short_help, + hidden=self.hidden, + deprecated=self.deprecated, + ) + return info_dict + + def get_usage(self, ctx: Context) -> str: + """Formats the usage line into a string and returns it. + + Calls :meth:`format_usage` internally. + """ + formatter = ctx.make_formatter() + self.format_usage(ctx, formatter) + return formatter.getvalue().rstrip("\n") + + def get_params(self, ctx: Context) -> t.List["Parameter"]: + rv = self.params + help_option = self.get_help_option(ctx) + + if help_option is not None: + rv = [*rv, help_option] + + return rv + + def format_usage(self, ctx: Context, formatter: HelpFormatter) -> None: + """Writes the usage line into the formatter. + + This is a low-level method called by :meth:`get_usage`. + """ + pieces = self.collect_usage_pieces(ctx) + formatter.write_usage(ctx.command_path, " ".join(pieces)) + + def collect_usage_pieces(self, ctx: Context) -> t.List[str]: + """Returns all the pieces that go into the usage line and returns + it as a list of strings. + """ + rv = [self.options_metavar] if self.options_metavar else [] + + for param in self.get_params(ctx): + rv.extend(param.get_usage_pieces(ctx)) + + return rv + + def get_help_option_names(self, ctx: Context) -> t.List[str]: + """Returns the names for the help option.""" + all_names = set(ctx.help_option_names) + for param in self.params: + all_names.difference_update(param.opts) + all_names.difference_update(param.secondary_opts) + return list(all_names) + + def get_help_option(self, ctx: Context) -> t.Optional["Option"]: + """Returns the help option object.""" + help_options = self.get_help_option_names(ctx) + + if not help_options or not self.add_help_option: + return None + + def show_help(ctx: Context, param: "Parameter", value: str) -> None: + if value and not ctx.resilient_parsing: + echo(ctx.get_help(), color=ctx.color) + ctx.exit() + + return Option( + help_options, + is_flag=True, + is_eager=True, + expose_value=False, + callback=show_help, + help=_("Show this message and exit."), + ) + + def make_parser(self, ctx: Context) -> OptionParser: + """Creates the underlying option parser for this command.""" + parser = OptionParser(ctx) + for param in self.get_params(ctx): + param.add_to_parser(parser, ctx) + return parser + + def get_help(self, ctx: Context) -> str: + """Formats the help into a string and returns it. + + Calls :meth:`format_help` internally. + """ + formatter = ctx.make_formatter() + self.format_help(ctx, formatter) + return formatter.getvalue().rstrip("\n") + + def get_short_help_str(self, limit: int = 45) -> str: + """Gets short help for the command or makes it by shortening the + long help string. + """ + text = self.short_help or "" + + if not text and self.help: + text = make_default_short_help(self.help, limit) + + if self.deprecated: + text = _("(Deprecated) {text}").format(text=text) + + return text.strip() + + def format_help(self, ctx: Context, formatter: HelpFormatter) -> None: + """Writes the help into the formatter if it exists. + + This is a low-level method called by :meth:`get_help`. + + This calls the following methods: + + - :meth:`format_usage` + - :meth:`format_help_text` + - :meth:`format_options` + - :meth:`format_epilog` + """ + self.format_usage(ctx, formatter) + self.format_help_text(ctx, formatter) + self.format_options(ctx, formatter) + self.format_epilog(ctx, formatter) + + def format_help_text(self, ctx: Context, formatter: HelpFormatter) -> None: + """Writes the help text to the formatter if it exists.""" + text = self.help or "" + + if self.deprecated: + text = _("(Deprecated) {text}").format(text=text) + + if text: + formatter.write_paragraph() + + with formatter.indentation(): + formatter.write_text(text) + + def format_options(self, ctx: Context, formatter: HelpFormatter) -> None: + """Writes all the options into the formatter if they exist.""" + opts = [] + for param in self.get_params(ctx): + rv = param.get_help_record(ctx) + if rv is not None: + opts.append(rv) + + if opts: + with formatter.section(_("Options")): + formatter.write_dl(opts) + + def format_epilog(self, ctx: Context, formatter: HelpFormatter) -> None: + """Writes the epilog into the formatter if it exists.""" + if self.epilog: + formatter.write_paragraph() + with formatter.indentation(): + formatter.write_text(self.epilog) + + def parse_args(self, ctx: Context, args: t.List[str]) -> t.List[str]: + if not args and self.no_args_is_help and not ctx.resilient_parsing: + echo(ctx.get_help(), color=ctx.color) + ctx.exit() + + parser = self.make_parser(ctx) + opts, args, param_order = parser.parse_args(args=args) + + for param in iter_params_for_processing(param_order, self.get_params(ctx)): + value, args = param.handle_parse_result(ctx, opts, args) + + if args and not ctx.allow_extra_args and not ctx.resilient_parsing: + ctx.fail( + ngettext( + "Got unexpected extra argument ({args})", + "Got unexpected extra arguments ({args})", + len(args), + ).format(args=" ".join(map(str, args))) + ) + + ctx.args = args + return args + + def invoke(self, ctx: Context) -> t.Any: + """Given a context, this invokes the attached callback (if it exists) + in the right way. + """ + if self.deprecated: + message = _( + "DeprecationWarning: The command {name!r} is deprecated." + ).format(name=self.name) + echo(style(message, fg="red"), err=True) + + if self.callback is not None: + return ctx.invoke(self.callback, **ctx.params) + + def shell_complete(self, ctx: Context, incomplete: str) -> t.List["CompletionItem"]: + """Return a list of completions for the incomplete value. Looks + at the names of options and chained multi-commands. + + :param ctx: Invocation context for this command. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + results: t.List["CompletionItem"] = [] + + if incomplete and not incomplete[0].isalnum(): + for param in self.get_params(ctx): + if ( + not isinstance(param, Option) + or param.hidden + or ( + not param.multiple + and ctx.get_parameter_source(param.name) # type: ignore + is ParameterSource.COMMANDLINE + ) + ): + continue + + results.extend( + CompletionItem(name, help=param.help) + for name in [*param.opts, *param.secondary_opts] + if name.startswith(incomplete) + ) + + results.extend(super().shell_complete(ctx, incomplete)) + return results + + +class MultiCommand(Command): + """A multi command is the basic implementation of a command that + dispatches to subcommands. The most common version is the + :class:`Group`. + + :param invoke_without_command: this controls how the multi command itself + is invoked. By default it's only invoked + if a subcommand is provided. + :param no_args_is_help: this controls what happens if no arguments are + provided. This option is enabled by default if + `invoke_without_command` is disabled or disabled + if it's enabled. If enabled this will add + ``--help`` as argument if no arguments are + passed. + :param subcommand_metavar: the string that is used in the documentation + to indicate the subcommand place. + :param chain: if this is set to `True` chaining of multiple subcommands + is enabled. This restricts the form of commands in that + they cannot have optional arguments but it allows + multiple commands to be chained together. + :param result_callback: The result callback to attach to this multi + command. This can be set or changed later with the + :meth:`result_callback` decorator. + """ + + allow_extra_args = True + allow_interspersed_args = False + + def __init__( + self, + name: t.Optional[str] = None, + invoke_without_command: bool = False, + no_args_is_help: t.Optional[bool] = None, + subcommand_metavar: t.Optional[str] = None, + chain: bool = False, + result_callback: t.Optional[t.Callable[..., t.Any]] = None, + **attrs: t.Any, + ) -> None: + super().__init__(name, **attrs) + + if no_args_is_help is None: + no_args_is_help = not invoke_without_command + + self.no_args_is_help = no_args_is_help + self.invoke_without_command = invoke_without_command + + if subcommand_metavar is None: + if chain: + subcommand_metavar = "COMMAND1 [ARGS]... [COMMAND2 [ARGS]...]..." + else: + subcommand_metavar = "COMMAND [ARGS]..." + + self.subcommand_metavar = subcommand_metavar + self.chain = chain + # The result callback that is stored. This can be set or + # overridden with the :func:`result_callback` decorator. + self._result_callback = result_callback + + if self.chain: + for param in self.params: + if isinstance(param, Argument) and not param.required: + raise RuntimeError( + "Multi commands in chain mode cannot have" + " optional arguments." + ) + + def to_info_dict(self, ctx: Context) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict(ctx) + commands = {} + + for name in self.list_commands(ctx): + command = self.get_command(ctx, name) + + if command is None: + continue + + sub_ctx = ctx._make_sub_context(command) + + with sub_ctx.scope(cleanup=False): + commands[name] = command.to_info_dict(sub_ctx) + + info_dict.update(commands=commands, chain=self.chain) + return info_dict + + def collect_usage_pieces(self, ctx: Context) -> t.List[str]: + rv = super().collect_usage_pieces(ctx) + rv.append(self.subcommand_metavar) + return rv + + def format_options(self, ctx: Context, formatter: HelpFormatter) -> None: + super().format_options(ctx, formatter) + self.format_commands(ctx, formatter) + + def result_callback(self, replace: bool = False) -> t.Callable[[F], F]: + """Adds a result callback to the command. By default if a + result callback is already registered this will chain them but + this can be disabled with the `replace` parameter. The result + callback is invoked with the return value of the subcommand + (or the list of return values from all subcommands if chaining + is enabled) as well as the parameters as they would be passed + to the main callback. + + Example:: + + @click.group() + @click.option('-i', '--input', default=23) + def cli(input): + return 42 + + @cli.result_callback() + def process_result(result, input): + return result + input + + :param replace: if set to `True` an already existing result + callback will be removed. + + .. versionchanged:: 8.0 + Renamed from ``resultcallback``. + + .. versionadded:: 3.0 + """ + + def decorator(f: F) -> F: + old_callback = self._result_callback + + if old_callback is None or replace: + self._result_callback = f + return f + + def function(__value, *args, **kwargs): # type: ignore + inner = old_callback(__value, *args, **kwargs) # type: ignore + return f(inner, *args, **kwargs) + + self._result_callback = rv = update_wrapper(t.cast(F, function), f) + return rv + + return decorator + + def resultcallback(self, replace: bool = False) -> t.Callable[[F], F]: + import warnings + + warnings.warn( + "'resultcallback' has been renamed to 'result_callback'." + " The old name will be removed in Click 8.1.", + DeprecationWarning, + stacklevel=2, + ) + return self.result_callback(replace=replace) + + def format_commands(self, ctx: Context, formatter: HelpFormatter) -> None: + """Extra format methods for multi methods that adds all the commands + after the options. + """ + commands = [] + for subcommand in self.list_commands(ctx): + cmd = self.get_command(ctx, subcommand) + # What is this, the tool lied about a command. Ignore it + if cmd is None: + continue + if cmd.hidden: + continue + + commands.append((subcommand, cmd)) + + # allow for 3 times the default spacing + if len(commands): + limit = formatter.width - 6 - max(len(cmd[0]) for cmd in commands) + + rows = [] + for subcommand, cmd in commands: + help = cmd.get_short_help_str(limit) + rows.append((subcommand, help)) + + if rows: + with formatter.section(_("Commands")): + formatter.write_dl(rows) + + def parse_args(self, ctx: Context, args: t.List[str]) -> t.List[str]: + if not args and self.no_args_is_help and not ctx.resilient_parsing: + echo(ctx.get_help(), color=ctx.color) + ctx.exit() + + rest = super().parse_args(ctx, args) + + if self.chain: + ctx.protected_args = rest + ctx.args = [] + elif rest: + ctx.protected_args, ctx.args = rest[:1], rest[1:] + + return ctx.args + + def invoke(self, ctx: Context) -> t.Any: + def _process_result(value: t.Any) -> t.Any: + if self._result_callback is not None: + value = ctx.invoke(self._result_callback, value, **ctx.params) + return value + + if not ctx.protected_args: + if self.invoke_without_command: + # No subcommand was invoked, so the result callback is + # invoked with None for regular groups, or an empty list + # for chained groups. + with ctx: + super().invoke(ctx) + return _process_result([] if self.chain else None) + ctx.fail(_("Missing command.")) + + # Fetch args back out + args = [*ctx.protected_args, *ctx.args] + ctx.args = [] + ctx.protected_args = [] + + # If we're not in chain mode, we only allow the invocation of a + # single command but we also inform the current context about the + # name of the command to invoke. + if not self.chain: + # Make sure the context is entered so we do not clean up + # resources until the result processor has worked. + with ctx: + cmd_name, cmd, args = self.resolve_command(ctx, args) + assert cmd is not None + ctx.invoked_subcommand = cmd_name + super().invoke(ctx) + sub_ctx = cmd.make_context(cmd_name, args, parent=ctx) + with sub_ctx: + return _process_result(sub_ctx.command.invoke(sub_ctx)) + + # In chain mode we create the contexts step by step, but after the + # base command has been invoked. Because at that point we do not + # know the subcommands yet, the invoked subcommand attribute is + # set to ``*`` to inform the command that subcommands are executed + # but nothing else. + with ctx: + ctx.invoked_subcommand = "*" if args else None + super().invoke(ctx) + + # Otherwise we make every single context and invoke them in a + # chain. In that case the return value to the result processor + # is the list of all invoked subcommand's results. + contexts = [] + while args: + cmd_name, cmd, args = self.resolve_command(ctx, args) + assert cmd is not None + sub_ctx = cmd.make_context( + cmd_name, + args, + parent=ctx, + allow_extra_args=True, + allow_interspersed_args=False, + ) + contexts.append(sub_ctx) + args, sub_ctx.args = sub_ctx.args, [] + + rv = [] + for sub_ctx in contexts: + with sub_ctx: + rv.append(sub_ctx.command.invoke(sub_ctx)) + return _process_result(rv) + + def resolve_command( + self, ctx: Context, args: t.List[str] + ) -> t.Tuple[t.Optional[str], t.Optional[Command], t.List[str]]: + cmd_name = make_str(args[0]) + original_cmd_name = cmd_name + + # Get the command + cmd = self.get_command(ctx, cmd_name) + + # If we can't find the command but there is a normalization + # function available, we try with that one. + if cmd is None and ctx.token_normalize_func is not None: + cmd_name = ctx.token_normalize_func(cmd_name) + cmd = self.get_command(ctx, cmd_name) + + # If we don't find the command we want to show an error message + # to the user that it was not provided. However, there is + # something else we should do: if the first argument looks like + # an option we want to kick off parsing again for arguments to + # resolve things like --help which now should go to the main + # place. + if cmd is None and not ctx.resilient_parsing: + if split_opt(cmd_name)[0]: + self.parse_args(ctx, ctx.args) + ctx.fail(_("No such command {name!r}.").format(name=original_cmd_name)) + return cmd_name if cmd else None, cmd, args[1:] + + def get_command(self, ctx: Context, cmd_name: str) -> t.Optional[Command]: + """Given a context and a command name, this returns a + :class:`Command` object if it exists or returns `None`. + """ + raise NotImplementedError + + def list_commands(self, ctx: Context) -> t.List[str]: + """Returns a list of subcommand names in the order they should + appear. + """ + return [] + + def shell_complete(self, ctx: Context, incomplete: str) -> t.List["CompletionItem"]: + """Return a list of completions for the incomplete value. Looks + at the names of options, subcommands, and chained + multi-commands. + + :param ctx: Invocation context for this command. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + results = [ + CompletionItem(name, help=command.get_short_help_str()) + for name, command in _complete_visible_commands(ctx, incomplete) + ] + results.extend(super().shell_complete(ctx, incomplete)) + return results + + +class Group(MultiCommand): + """A group allows a command to have subcommands attached. This is + the most common way to implement nesting in Click. + + :param name: The name of the group command. + :param commands: A dict mapping names to :class:`Command` objects. + Can also be a list of :class:`Command`, which will use + :attr:`Command.name` to create the dict. + :param attrs: Other command arguments described in + :class:`MultiCommand`, :class:`Command`, and + :class:`BaseCommand`. + + .. versionchanged:: 8.0 + The ``commmands`` argument can be a list of command objects. + """ + + #: If set, this is used by the group's :meth:`command` decorator + #: as the default :class:`Command` class. This is useful to make all + #: subcommands use a custom command class. + #: + #: .. versionadded:: 8.0 + command_class: t.Optional[t.Type[Command]] = None + + #: If set, this is used by the group's :meth:`group` decorator + #: as the default :class:`Group` class. This is useful to make all + #: subgroups use a custom group class. + #: + #: If set to the special value :class:`type` (literally + #: ``group_class = type``), this group's class will be used as the + #: default class. This makes a custom group class continue to make + #: custom groups. + #: + #: .. versionadded:: 8.0 + group_class: t.Optional[t.Union[t.Type["Group"], t.Type[type]]] = None + # Literal[type] isn't valid, so use Type[type] + + def __init__( + self, + name: t.Optional[str] = None, + commands: t.Optional[t.Union[t.Dict[str, Command], t.Sequence[Command]]] = None, + **attrs: t.Any, + ) -> None: + super().__init__(name, **attrs) + + if commands is None: + commands = {} + elif isinstance(commands, abc.Sequence): + commands = {c.name: c for c in commands if c.name is not None} + + #: The registered subcommands by their exported names. + self.commands: t.Dict[str, Command] = commands + + def add_command(self, cmd: Command, name: t.Optional[str] = None) -> None: + """Registers another :class:`Command` with this group. If the name + is not provided, the name of the command is used. + """ + name = name or cmd.name + if name is None: + raise TypeError("Command has no name.") + _check_multicommand(self, name, cmd, register=True) + self.commands[name] = cmd + + def command( + self, *args: t.Any, **kwargs: t.Any + ) -> t.Callable[[t.Callable[..., t.Any]], Command]: + """A shortcut decorator for declaring and attaching a command to + the group. This takes the same arguments as :func:`command` and + immediately registers the created command with this group by + calling :meth:`add_command`. + + To customize the command class used, set the + :attr:`command_class` attribute. + + .. versionchanged:: 8.0 + Added the :attr:`command_class` attribute. + """ + from .decorators import command + + if self.command_class is not None and "cls" not in kwargs: + kwargs["cls"] = self.command_class + + def decorator(f: t.Callable[..., t.Any]) -> Command: + cmd = command(*args, **kwargs)(f) + self.add_command(cmd) + return cmd + + return decorator + + def group( + self, *args: t.Any, **kwargs: t.Any + ) -> t.Callable[[t.Callable[..., t.Any]], "Group"]: + """A shortcut decorator for declaring and attaching a group to + the group. This takes the same arguments as :func:`group` and + immediately registers the created group with this group by + calling :meth:`add_command`. + + To customize the group class used, set the :attr:`group_class` + attribute. + + .. versionchanged:: 8.0 + Added the :attr:`group_class` attribute. + """ + from .decorators import group + + if self.group_class is not None and "cls" not in kwargs: + if self.group_class is type: + kwargs["cls"] = type(self) + else: + kwargs["cls"] = self.group_class + + def decorator(f: t.Callable[..., t.Any]) -> "Group": + cmd = group(*args, **kwargs)(f) + self.add_command(cmd) + return cmd + + return decorator + + def get_command(self, ctx: Context, cmd_name: str) -> t.Optional[Command]: + return self.commands.get(cmd_name) + + def list_commands(self, ctx: Context) -> t.List[str]: + return sorted(self.commands) + + +class CommandCollection(MultiCommand): + """A command collection is a multi command that merges multiple multi + commands together into one. This is a straightforward implementation + that accepts a list of different multi commands as sources and + provides all the commands for each of them. + """ + + def __init__( + self, + name: t.Optional[str] = None, + sources: t.Optional[t.List[MultiCommand]] = None, + **attrs: t.Any, + ) -> None: + super().__init__(name, **attrs) + #: The list of registered multi commands. + self.sources: t.List[MultiCommand] = sources or [] + + def add_source(self, multi_cmd: MultiCommand) -> None: + """Adds a new multi command to the chain dispatcher.""" + self.sources.append(multi_cmd) + + def get_command(self, ctx: Context, cmd_name: str) -> t.Optional[Command]: + for source in self.sources: + rv = source.get_command(ctx, cmd_name) + + if rv is not None: + if self.chain: + _check_multicommand(self, cmd_name, rv) + + return rv + + return None + + def list_commands(self, ctx: Context) -> t.List[str]: + rv: t.Set[str] = set() + + for source in self.sources: + rv.update(source.list_commands(ctx)) + + return sorted(rv) + + +def _check_iter(value: t.Any) -> t.Iterator[t.Any]: + """Check if the value is iterable but not a string. Raises a type + error, or return an iterator over the value. + """ + if isinstance(value, str): + raise TypeError + + return iter(value) + + +class Parameter: + r"""A parameter to a command comes in two versions: they are either + :class:`Option`\s or :class:`Argument`\s. Other subclasses are currently + not supported by design as some of the internals for parsing are + intentionally not finalized. + + Some settings are supported by both options and arguments. + + :param param_decls: the parameter declarations for this option or + argument. This is a list of flags or argument + names. + :param type: the type that should be used. Either a :class:`ParamType` + or a Python type. The later is converted into the former + automatically if supported. + :param required: controls if this is optional or not. + :param default: the default value if omitted. This can also be a callable, + in which case it's invoked when the default is needed + without any arguments. + :param callback: A function to further process or validate the value + after type conversion. It is called as ``f(ctx, param, value)`` + and must return the value. It is called for all sources, + including prompts. + :param nargs: the number of arguments to match. If not ``1`` the return + value is a tuple instead of single value. The default for + nargs is ``1`` (except if the type is a tuple, then it's + the arity of the tuple). If ``nargs=-1``, all remaining + parameters are collected. + :param metavar: how the value is represented in the help page. + :param expose_value: if this is `True` then the value is passed onwards + to the command callback and stored on the context, + otherwise it's skipped. + :param is_eager: eager values are processed before non eager ones. This + should not be set for arguments or it will inverse the + order of processing. + :param envvar: a string or list of strings that are environment variables + that should be checked. + :param shell_complete: A function that returns custom shell + completions. Used instead of the param's type completion if + given. Takes ``ctx, param, incomplete`` and must return a list + of :class:`~click.shell_completion.CompletionItem` or a list of + strings. + + .. versionchanged:: 8.0 + ``process_value`` validates required parameters and bounded + ``nargs``, and invokes the parameter callback before returning + the value. This allows the callback to validate prompts. + ``full_process_value`` is removed. + + .. versionchanged:: 8.0 + ``autocompletion`` is renamed to ``shell_complete`` and has new + semantics described above. The old name is deprecated and will + be removed in 8.1, until then it will be wrapped to match the + new requirements. + + .. versionchanged:: 8.0 + For ``multiple=True, nargs>1``, the default must be a list of + tuples. + + .. versionchanged:: 8.0 + Setting a default is no longer required for ``nargs>1``, it will + default to ``None``. ``multiple=True`` or ``nargs=-1`` will + default to ``()``. + + .. versionchanged:: 7.1 + Empty environment variables are ignored rather than taking the + empty string value. This makes it possible for scripts to clear + variables if they can't unset them. + + .. versionchanged:: 2.0 + Changed signature for parameter callback to also be passed the + parameter. The old callback format will still work, but it will + raise a warning to give you a chance to migrate the code easier. + """ + + param_type_name = "parameter" + + def __init__( + self, + param_decls: t.Optional[t.Sequence[str]] = None, + type: t.Optional[t.Union[types.ParamType, t.Any]] = None, + required: bool = False, + default: t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]] = None, + callback: t.Optional[t.Callable[[Context, "Parameter", t.Any], t.Any]] = None, + nargs: t.Optional[int] = None, + multiple: bool = False, + metavar: t.Optional[str] = None, + expose_value: bool = True, + is_eager: bool = False, + envvar: t.Optional[t.Union[str, t.Sequence[str]]] = None, + shell_complete: t.Optional[ + t.Callable[ + [Context, "Parameter", str], + t.Union[t.List["CompletionItem"], t.List[str]], + ] + ] = None, + autocompletion: t.Optional[ + t.Callable[ + [Context, t.List[str], str], t.List[t.Union[t.Tuple[str, str], str]] + ] + ] = None, + ) -> None: + self.name, self.opts, self.secondary_opts = self._parse_decls( + param_decls or (), expose_value + ) + self.type = types.convert_type(type, default) + + # Default nargs to what the type tells us if we have that + # information available. + if nargs is None: + if self.type.is_composite: + nargs = self.type.arity + else: + nargs = 1 + + self.required = required + self.callback = callback + self.nargs = nargs + self.multiple = multiple + self.expose_value = expose_value + self.default = default + self.is_eager = is_eager + self.metavar = metavar + self.envvar = envvar + + if autocompletion is not None: + import warnings + + warnings.warn( + "'autocompletion' is renamed to 'shell_complete'. The old name is" + " deprecated and will be removed in Click 8.1. See the docs about" + " 'Parameter' for information about new behavior.", + DeprecationWarning, + stacklevel=2, + ) + + def shell_complete( + ctx: Context, param: "Parameter", incomplete: str + ) -> t.List["CompletionItem"]: + from click.shell_completion import CompletionItem + + out = [] + + for c in autocompletion(ctx, [], incomplete): # type: ignore + if isinstance(c, tuple): + c = CompletionItem(c[0], help=c[1]) + elif isinstance(c, str): + c = CompletionItem(c) + + if c.value.startswith(incomplete): + out.append(c) + + return out + + self._custom_shell_complete = shell_complete + + if __debug__: + if self.type.is_composite and nargs != self.type.arity: + raise ValueError( + f"'nargs' must be {self.type.arity} (or None) for" + f" type {self.type!r}, but it was {nargs}." + ) + + # Skip no default or callable default. + check_default = default if not callable(default) else None + + if check_default is not None: + if multiple: + try: + # Only check the first value against nargs. + check_default = next(_check_iter(check_default), None) + except TypeError: + raise ValueError( + "'default' must be a list when 'multiple' is true." + ) from None + + # Can be None for multiple with empty default. + if nargs != 1 and check_default is not None: + try: + _check_iter(check_default) + except TypeError: + if multiple: + message = ( + "'default' must be a list of lists when 'multiple' is" + " true and 'nargs' != 1." + ) + else: + message = "'default' must be a list when 'nargs' != 1." + + raise ValueError(message) from None + + if nargs > 1 and len(check_default) != nargs: + subject = "item length" if multiple else "length" + raise ValueError( + f"'default' {subject} must match nargs={nargs}." + ) + + def to_info_dict(self) -> t.Dict[str, t.Any]: + """Gather information that could be useful for a tool generating + user-facing documentation. + + Use :meth:`click.Context.to_info_dict` to traverse the entire + CLI structure. + + .. versionadded:: 8.0 + """ + return { + "name": self.name, + "param_type_name": self.param_type_name, + "opts": self.opts, + "secondary_opts": self.secondary_opts, + "type": self.type.to_info_dict(), + "required": self.required, + "nargs": self.nargs, + "multiple": self.multiple, + "default": self.default, + "envvar": self.envvar, + } + + def __repr__(self) -> str: + return f"<{self.__class__.__name__} {self.name}>" + + def _parse_decls( + self, decls: t.Sequence[str], expose_value: bool + ) -> t.Tuple[t.Optional[str], t.List[str], t.List[str]]: + raise NotImplementedError() + + @property + def human_readable_name(self) -> str: + """Returns the human readable name of this parameter. This is the + same as the name for options, but the metavar for arguments. + """ + return self.name # type: ignore + + def make_metavar(self) -> str: + if self.metavar is not None: + return self.metavar + + metavar = self.type.get_metavar(self) + + if metavar is None: + metavar = self.type.name.upper() + + if self.nargs != 1: + metavar += "..." + + return metavar + + @typing.overload + def get_default( + self, ctx: Context, call: "te.Literal[True]" = True + ) -> t.Optional[t.Any]: + ... + + @typing.overload + def get_default( + self, ctx: Context, call: bool = ... + ) -> t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]]: + ... + + def get_default( + self, ctx: Context, call: bool = True + ) -> t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]]: + """Get the default for the parameter. Tries + :meth:`Context.lookup_default` first, then the local default. + + :param ctx: Current context. + :param call: If the default is a callable, call it. Disable to + return the callable instead. + + .. versionchanged:: 8.0.2 + Type casting is no longer performed when getting a default. + + .. versionchanged:: 8.0.1 + Type casting can fail in resilient parsing mode. Invalid + defaults will not prevent showing help text. + + .. versionchanged:: 8.0 + Looks at ``ctx.default_map`` first. + + .. versionchanged:: 8.0 + Added the ``call`` parameter. + """ + value = ctx.lookup_default(self.name, call=False) # type: ignore + + if value is None: + value = self.default + + if call and callable(value): + value = value() + + return value + + def add_to_parser(self, parser: OptionParser, ctx: Context) -> None: + raise NotImplementedError() + + def consume_value( + self, ctx: Context, opts: t.Mapping[str, t.Any] + ) -> t.Tuple[t.Any, ParameterSource]: + value = opts.get(self.name) # type: ignore + source = ParameterSource.COMMANDLINE + + if value is None: + value = self.value_from_envvar(ctx) + source = ParameterSource.ENVIRONMENT + + if value is None: + value = ctx.lookup_default(self.name) # type: ignore + source = ParameterSource.DEFAULT_MAP + + if value is None: + value = self.get_default(ctx) + source = ParameterSource.DEFAULT + + return value, source + + def type_cast_value(self, ctx: Context, value: t.Any) -> t.Any: + """Convert and validate a value against the option's + :attr:`type`, :attr:`multiple`, and :attr:`nargs`. + """ + if value is None: + return () if self.multiple or self.nargs == -1 else None + + def check_iter(value: t.Any) -> t.Iterator: + try: + return _check_iter(value) + except TypeError: + # This should only happen when passing in args manually, + # the parser should construct an iterable when parsing + # the command line. + raise BadParameter( + _("Value must be an iterable."), ctx=ctx, param=self + ) from None + + if self.nargs == 1 or self.type.is_composite: + convert: t.Callable[[t.Any], t.Any] = partial( + self.type, param=self, ctx=ctx + ) + elif self.nargs == -1: + + def convert(value: t.Any) -> t.Tuple: + return tuple(self.type(x, self, ctx) for x in check_iter(value)) + + else: # nargs > 1 + + def convert(value: t.Any) -> t.Tuple: + value = tuple(check_iter(value)) + + if len(value) != self.nargs: + raise BadParameter( + ngettext( + "Takes {nargs} values but 1 was given.", + "Takes {nargs} values but {len} were given.", + len(value), + ).format(nargs=self.nargs, len=len(value)), + ctx=ctx, + param=self, + ) + + return tuple(self.type(x, self, ctx) for x in value) + + if self.multiple: + return tuple(convert(x) for x in check_iter(value)) + + return convert(value) + + def value_is_missing(self, value: t.Any) -> bool: + if value is None: + return True + + if (self.nargs != 1 or self.multiple) and value == (): + return True + + return False + + def process_value(self, ctx: Context, value: t.Any) -> t.Any: + value = self.type_cast_value(ctx, value) + + if self.required and self.value_is_missing(value): + raise MissingParameter(ctx=ctx, param=self) + + if self.callback is not None: + value = self.callback(ctx, self, value) + + return value + + def resolve_envvar_value(self, ctx: Context) -> t.Optional[str]: + if self.envvar is None: + return None + + if isinstance(self.envvar, str): + rv = os.environ.get(self.envvar) + + if rv: + return rv + else: + for envvar in self.envvar: + rv = os.environ.get(envvar) + + if rv: + return rv + + return None + + def value_from_envvar(self, ctx: Context) -> t.Optional[t.Any]: + rv: t.Optional[t.Any] = self.resolve_envvar_value(ctx) + + if rv is not None and self.nargs != 1: + rv = self.type.split_envvar_value(rv) + + return rv + + def handle_parse_result( + self, ctx: Context, opts: t.Mapping[str, t.Any], args: t.List[str] + ) -> t.Tuple[t.Any, t.List[str]]: + with augment_usage_errors(ctx, param=self): + value, source = self.consume_value(ctx, opts) + ctx.set_parameter_source(self.name, source) # type: ignore + + try: + value = self.process_value(ctx, value) + except Exception: + if not ctx.resilient_parsing: + raise + + value = None + + if self.expose_value: + ctx.params[self.name] = value # type: ignore + + return value, args + + def get_help_record(self, ctx: Context) -> t.Optional[t.Tuple[str, str]]: + pass + + def get_usage_pieces(self, ctx: Context) -> t.List[str]: + return [] + + def get_error_hint(self, ctx: Context) -> str: + """Get a stringified version of the param for use in error messages to + indicate which param caused the error. + """ + hint_list = self.opts or [self.human_readable_name] + return " / ".join(f"'{x}'" for x in hint_list) + + def shell_complete(self, ctx: Context, incomplete: str) -> t.List["CompletionItem"]: + """Return a list of completions for the incomplete value. If a + ``shell_complete`` function was given during init, it is used. + Otherwise, the :attr:`type` + :meth:`~click.types.ParamType.shell_complete` function is used. + + :param ctx: Invocation context for this command. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + if self._custom_shell_complete is not None: + results = self._custom_shell_complete(ctx, self, incomplete) + + if results and isinstance(results[0], str): + from click.shell_completion import CompletionItem + + results = [CompletionItem(c) for c in results] + + return t.cast(t.List["CompletionItem"], results) + + return self.type.shell_complete(ctx, self, incomplete) + + +class Option(Parameter): + """Options are usually optional values on the command line and + have some extra features that arguments don't have. + + All other parameters are passed onwards to the parameter constructor. + + :param show_default: controls if the default value should be shown on the + help page. Normally, defaults are not shown. If this + value is a string, it shows the string instead of the + value. This is particularly useful for dynamic options. + :param show_envvar: controls if an environment variable should be shown on + the help page. Normally, environment variables + are not shown. + :param prompt: if set to `True` or a non empty string then the user will be + prompted for input. If set to `True` the prompt will be the + option name capitalized. + :param confirmation_prompt: Prompt a second time to confirm the + value if it was prompted for. Can be set to a string instead of + ``True`` to customize the message. + :param prompt_required: If set to ``False``, the user will be + prompted for input only when the option was specified as a flag + without a value. + :param hide_input: if this is `True` then the input on the prompt will be + hidden from the user. This is useful for password + input. + :param is_flag: forces this option to act as a flag. The default is + auto detection. + :param flag_value: which value should be used for this flag if it's + enabled. This is set to a boolean automatically if + the option string contains a slash to mark two options. + :param multiple: if this is set to `True` then the argument is accepted + multiple times and recorded. This is similar to ``nargs`` + in how it works but supports arbitrary number of + arguments. + :param count: this flag makes an option increment an integer. + :param allow_from_autoenv: if this is enabled then the value of this + parameter will be pulled from an environment + variable in case a prefix is defined on the + context. + :param help: the help string. + :param hidden: hide this option from help outputs. + + .. versionchanged:: 8.0.1 + ``type`` is detected from ``flag_value`` if given. + """ + + param_type_name = "option" + + def __init__( + self, + param_decls: t.Optional[t.Sequence[str]] = None, + show_default: t.Union[bool, str] = False, + prompt: t.Union[bool, str] = False, + confirmation_prompt: t.Union[bool, str] = False, + prompt_required: bool = True, + hide_input: bool = False, + is_flag: t.Optional[bool] = None, + flag_value: t.Optional[t.Any] = None, + multiple: bool = False, + count: bool = False, + allow_from_autoenv: bool = True, + type: t.Optional[t.Union[types.ParamType, t.Any]] = None, + help: t.Optional[str] = None, + hidden: bool = False, + show_choices: bool = True, + show_envvar: bool = False, + **attrs: t.Any, + ) -> None: + default_is_missing = "default" not in attrs + super().__init__(param_decls, type=type, multiple=multiple, **attrs) + + if prompt is True: + if self.name is None: + raise TypeError("'name' is required with 'prompt=True'.") + + prompt_text: t.Optional[str] = self.name.replace("_", " ").capitalize() + elif prompt is False: + prompt_text = None + else: + prompt_text = t.cast(str, prompt) + + self.prompt = prompt_text + self.confirmation_prompt = confirmation_prompt + self.prompt_required = prompt_required + self.hide_input = hide_input + self.hidden = hidden + + # If prompt is enabled but not required, then the option can be + # used as a flag to indicate using prompt or flag_value. + self._flag_needs_value = self.prompt is not None and not self.prompt_required + + if is_flag is None: + if flag_value is not None: + # Implicitly a flag because flag_value was set. + is_flag = True + elif self._flag_needs_value: + # Not a flag, but when used as a flag it shows a prompt. + is_flag = False + else: + # Implicitly a flag because flag options were given. + is_flag = bool(self.secondary_opts) + elif is_flag is False and not self._flag_needs_value: + # Not a flag, and prompt is not enabled, can be used as a + # flag if flag_value is set. + self._flag_needs_value = flag_value is not None + + if is_flag and default_is_missing: + self.default: t.Union[t.Any, t.Callable[[], t.Any]] = False + + if flag_value is None: + flag_value = not self.default + + if is_flag and type is None: + # Re-guess the type from the flag value instead of the + # default. + self.type = types.convert_type(None, flag_value) + + self.is_flag: bool = is_flag + self.is_bool_flag = is_flag and isinstance(self.type, types.BoolParamType) + self.flag_value: t.Any = flag_value + + # Counting + self.count = count + if count: + if type is None: + self.type = types.IntRange(min=0) + if default_is_missing: + self.default = 0 + + self.allow_from_autoenv = allow_from_autoenv + self.help = help + self.show_default = show_default + self.show_choices = show_choices + self.show_envvar = show_envvar + + if __debug__: + if self.nargs == -1: + raise TypeError("nargs=-1 is not supported for options.") + + if self.prompt and self.is_flag and not self.is_bool_flag: + raise TypeError("'prompt' is not valid for non-boolean flag.") + + if not self.is_bool_flag and self.secondary_opts: + raise TypeError("Secondary flag is not valid for non-boolean flag.") + + if self.is_bool_flag and self.hide_input and self.prompt is not None: + raise TypeError( + "'prompt' with 'hide_input' is not valid for boolean flag." + ) + + if self.count: + if self.multiple: + raise TypeError("'count' is not valid with 'multiple'.") + + if self.is_flag: + raise TypeError("'count' is not valid with 'is_flag'.") + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict.update( + help=self.help, + prompt=self.prompt, + is_flag=self.is_flag, + flag_value=self.flag_value, + count=self.count, + hidden=self.hidden, + ) + return info_dict + + def _parse_decls( + self, decls: t.Sequence[str], expose_value: bool + ) -> t.Tuple[t.Optional[str], t.List[str], t.List[str]]: + opts = [] + secondary_opts = [] + name = None + possible_names = [] + + for decl in decls: + if decl.isidentifier(): + if name is not None: + raise TypeError(f"Name '{name}' defined twice") + name = decl + else: + split_char = ";" if decl[:1] == "/" else "/" + if split_char in decl: + first, second = decl.split(split_char, 1) + first = first.rstrip() + if first: + possible_names.append(split_opt(first)) + opts.append(first) + second = second.lstrip() + if second: + secondary_opts.append(second.lstrip()) + if first == second: + raise ValueError( + f"Boolean option {decl!r} cannot use the" + " same flag for true/false." + ) + else: + possible_names.append(split_opt(decl)) + opts.append(decl) + + if name is None and possible_names: + possible_names.sort(key=lambda x: -len(x[0])) # group long options first + name = possible_names[0][1].replace("-", "_").lower() + if not name.isidentifier(): + name = None + + if name is None: + if not expose_value: + return None, opts, secondary_opts + raise TypeError("Could not determine name for option") + + if not opts and not secondary_opts: + raise TypeError( + f"No options defined but a name was passed ({name})." + " Did you mean to declare an argument instead? Did" + f" you mean to pass '--{name}'?" + ) + + return name, opts, secondary_opts + + def add_to_parser(self, parser: OptionParser, ctx: Context) -> None: + if self.multiple: + action = "append" + elif self.count: + action = "count" + else: + action = "store" + + if self.is_flag: + action = f"{action}_const" + + if self.is_bool_flag and self.secondary_opts: + parser.add_option( + obj=self, opts=self.opts, dest=self.name, action=action, const=True + ) + parser.add_option( + obj=self, + opts=self.secondary_opts, + dest=self.name, + action=action, + const=False, + ) + else: + parser.add_option( + obj=self, + opts=self.opts, + dest=self.name, + action=action, + const=self.flag_value, + ) + else: + parser.add_option( + obj=self, + opts=self.opts, + dest=self.name, + action=action, + nargs=self.nargs, + ) + + def get_help_record(self, ctx: Context) -> t.Optional[t.Tuple[str, str]]: + if self.hidden: + return None + + any_prefix_is_slash = False + + def _write_opts(opts: t.Sequence[str]) -> str: + nonlocal any_prefix_is_slash + + rv, any_slashes = join_options(opts) + + if any_slashes: + any_prefix_is_slash = True + + if not self.is_flag and not self.count: + rv += f" {self.make_metavar()}" + + return rv + + rv = [_write_opts(self.opts)] + + if self.secondary_opts: + rv.append(_write_opts(self.secondary_opts)) + + help = self.help or "" + extra = [] + + if self.show_envvar: + envvar = self.envvar + + if envvar is None: + if ( + self.allow_from_autoenv + and ctx.auto_envvar_prefix is not None + and self.name is not None + ): + envvar = f"{ctx.auto_envvar_prefix}_{self.name.upper()}" + + if envvar is not None: + var_str = ( + envvar + if isinstance(envvar, str) + else ", ".join(str(d) for d in envvar) + ) + extra.append(_("env var: {var}").format(var=var_str)) + + # Temporarily enable resilient parsing to avoid type casting + # failing for the default. Might be possible to extend this to + # help formatting in general. + resilient = ctx.resilient_parsing + ctx.resilient_parsing = True + + try: + default_value = self.get_default(ctx, call=False) + finally: + ctx.resilient_parsing = resilient + + show_default_is_str = isinstance(self.show_default, str) + + if show_default_is_str or ( + default_value is not None and (self.show_default or ctx.show_default) + ): + if show_default_is_str: + default_string = f"({self.show_default})" + elif isinstance(default_value, (list, tuple)): + default_string = ", ".join(str(d) for d in default_value) + elif callable(default_value): + default_string = _("(dynamic)") + elif self.is_bool_flag and self.secondary_opts: + # For boolean flags that have distinct True/False opts, + # use the opt without prefix instead of the value. + default_string = split_opt( + (self.opts if self.default else self.secondary_opts)[0] + )[1] + else: + default_string = str(default_value) + + if default_string: + extra.append(_("default: {default}").format(default=default_string)) + + if ( + isinstance(self.type, types._NumberRangeBase) + # skip count with default range type + and not (self.count and self.type.min == 0 and self.type.max is None) + ): + range_str = self.type._describe_range() + + if range_str: + extra.append(range_str) + + if self.required: + extra.append(_("required")) + + if extra: + extra_str = "; ".join(extra) + help = f"{help} [{extra_str}]" if help else f"[{extra_str}]" + + return ("; " if any_prefix_is_slash else " / ").join(rv), help + + @typing.overload + def get_default( + self, ctx: Context, call: "te.Literal[True]" = True + ) -> t.Optional[t.Any]: + ... + + @typing.overload + def get_default( + self, ctx: Context, call: bool = ... + ) -> t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]]: + ... + + def get_default( + self, ctx: Context, call: bool = True + ) -> t.Optional[t.Union[t.Any, t.Callable[[], t.Any]]]: + # If we're a non boolean flag our default is more complex because + # we need to look at all flags in the same group to figure out + # if we're the the default one in which case we return the flag + # value as default. + if self.is_flag and not self.is_bool_flag: + for param in ctx.command.params: + if param.name == self.name and param.default: + return param.flag_value # type: ignore + + return None + + return super().get_default(ctx, call=call) + + def prompt_for_value(self, ctx: Context) -> t.Any: + """This is an alternative flow that can be activated in the full + value processing if a value does not exist. It will prompt the + user until a valid value exists and then returns the processed + value as result. + """ + assert self.prompt is not None + + # Calculate the default before prompting anything to be stable. + default = self.get_default(ctx) + + # If this is a prompt for a flag we need to handle this + # differently. + if self.is_bool_flag: + return confirm(self.prompt, default) + + return prompt( + self.prompt, + default=default, + type=self.type, + hide_input=self.hide_input, + show_choices=self.show_choices, + confirmation_prompt=self.confirmation_prompt, + value_proc=lambda x: self.process_value(ctx, x), + ) + + def resolve_envvar_value(self, ctx: Context) -> t.Optional[str]: + rv = super().resolve_envvar_value(ctx) + + if rv is not None: + return rv + + if ( + self.allow_from_autoenv + and ctx.auto_envvar_prefix is not None + and self.name is not None + ): + envvar = f"{ctx.auto_envvar_prefix}_{self.name.upper()}" + rv = os.environ.get(envvar) + + return rv + + def value_from_envvar(self, ctx: Context) -> t.Optional[t.Any]: + rv: t.Optional[t.Any] = self.resolve_envvar_value(ctx) + + if rv is None: + return None + + value_depth = (self.nargs != 1) + bool(self.multiple) + + if value_depth > 0: + rv = self.type.split_envvar_value(rv) + + if self.multiple and self.nargs != 1: + rv = batch(rv, self.nargs) + + return rv + + def consume_value( + self, ctx: Context, opts: t.Mapping[str, "Parameter"] + ) -> t.Tuple[t.Any, ParameterSource]: + value, source = super().consume_value(ctx, opts) + + # The parser will emit a sentinel value if the option can be + # given as a flag without a value. This is different from None + # to distinguish from the flag not being given at all. + if value is _flag_needs_value: + if self.prompt is not None and not ctx.resilient_parsing: + value = self.prompt_for_value(ctx) + source = ParameterSource.PROMPT + else: + value = self.flag_value + source = ParameterSource.COMMANDLINE + + elif ( + self.multiple + and value is not None + and any(v is _flag_needs_value for v in value) + ): + value = [self.flag_value if v is _flag_needs_value else v for v in value] + source = ParameterSource.COMMANDLINE + + # The value wasn't set, or used the param's default, prompt if + # prompting is enabled. + elif ( + source in {None, ParameterSource.DEFAULT} + and self.prompt is not None + and (self.required or self.prompt_required) + and not ctx.resilient_parsing + ): + value = self.prompt_for_value(ctx) + source = ParameterSource.PROMPT + + return value, source + + +class Argument(Parameter): + """Arguments are positional parameters to a command. They generally + provide fewer features than options but can have infinite ``nargs`` + and are required by default. + + All parameters are passed onwards to the parameter constructor. + """ + + param_type_name = "argument" + + def __init__( + self, + param_decls: t.Sequence[str], + required: t.Optional[bool] = None, + **attrs: t.Any, + ) -> None: + if required is None: + if attrs.get("default") is not None: + required = False + else: + required = attrs.get("nargs", 1) > 0 + + if "multiple" in attrs: + raise TypeError("__init__() got an unexpected keyword argument 'multiple'.") + + super().__init__(param_decls, required=required, **attrs) + + if __debug__: + if self.default is not None and self.nargs == -1: + raise TypeError("'default' is not supported for nargs=-1.") + + @property + def human_readable_name(self) -> str: + if self.metavar is not None: + return self.metavar + return self.name.upper() # type: ignore + + def make_metavar(self) -> str: + if self.metavar is not None: + return self.metavar + var = self.type.get_metavar(self) + if not var: + var = self.name.upper() # type: ignore + if not self.required: + var = f"[{var}]" + if self.nargs != 1: + var += "..." + return var + + def _parse_decls( + self, decls: t.Sequence[str], expose_value: bool + ) -> t.Tuple[t.Optional[str], t.List[str], t.List[str]]: + if not decls: + if not expose_value: + return None, [], [] + raise TypeError("Could not determine name for argument") + if len(decls) == 1: + name = arg = decls[0] + name = name.replace("-", "_").lower() + else: + raise TypeError( + "Arguments take exactly one parameter declaration, got" + f" {len(decls)}." + ) + return name, [arg], [] + + def get_usage_pieces(self, ctx: Context) -> t.List[str]: + return [self.make_metavar()] + + def get_error_hint(self, ctx: Context) -> str: + return f"'{self.make_metavar()}'" + + def add_to_parser(self, parser: OptionParser, ctx: Context) -> None: + parser.add_argument(dest=self.name, nargs=self.nargs, obj=self) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/decorators.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/decorators.py new file mode 100644 index 00000000..f1cc005a --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/decorators.py @@ -0,0 +1,436 @@ +import inspect +import types +import typing as t +from functools import update_wrapper +from gettext import gettext as _ + +from .core import Argument +from .core import Command +from .core import Context +from .core import Group +from .core import Option +from .core import Parameter +from .globals import get_current_context +from .utils import echo + +F = t.TypeVar("F", bound=t.Callable[..., t.Any]) +FC = t.TypeVar("FC", t.Callable[..., t.Any], Command) + + +def pass_context(f: F) -> F: + """Marks a callback as wanting to receive the current context + object as first argument. + """ + + def new_func(*args, **kwargs): # type: ignore + return f(get_current_context(), *args, **kwargs) + + return update_wrapper(t.cast(F, new_func), f) + + +def pass_obj(f: F) -> F: + """Similar to :func:`pass_context`, but only pass the object on the + context onwards (:attr:`Context.obj`). This is useful if that object + represents the state of a nested system. + """ + + def new_func(*args, **kwargs): # type: ignore + return f(get_current_context().obj, *args, **kwargs) + + return update_wrapper(t.cast(F, new_func), f) + + +def make_pass_decorator( + object_type: t.Type, ensure: bool = False +) -> "t.Callable[[F], F]": + """Given an object type this creates a decorator that will work + similar to :func:`pass_obj` but instead of passing the object of the + current context, it will find the innermost context of type + :func:`object_type`. + + This generates a decorator that works roughly like this:: + + from functools import update_wrapper + + def decorator(f): + @pass_context + def new_func(ctx, *args, **kwargs): + obj = ctx.find_object(object_type) + return ctx.invoke(f, obj, *args, **kwargs) + return update_wrapper(new_func, f) + return decorator + + :param object_type: the type of the object to pass. + :param ensure: if set to `True`, a new object will be created and + remembered on the context if it's not there yet. + """ + + def decorator(f: F) -> F: + def new_func(*args, **kwargs): # type: ignore + ctx = get_current_context() + + if ensure: + obj = ctx.ensure_object(object_type) + else: + obj = ctx.find_object(object_type) + + if obj is None: + raise RuntimeError( + "Managed to invoke callback without a context" + f" object of type {object_type.__name__!r}" + " existing." + ) + + return ctx.invoke(f, obj, *args, **kwargs) + + return update_wrapper(t.cast(F, new_func), f) + + return decorator + + +def pass_meta_key( + key: str, *, doc_description: t.Optional[str] = None +) -> "t.Callable[[F], F]": + """Create a decorator that passes a key from + :attr:`click.Context.meta` as the first argument to the decorated + function. + + :param key: Key in ``Context.meta`` to pass. + :param doc_description: Description of the object being passed, + inserted into the decorator's docstring. Defaults to "the 'key' + key from Context.meta". + + .. versionadded:: 8.0 + """ + + def decorator(f: F) -> F: + def new_func(*args, **kwargs): # type: ignore + ctx = get_current_context() + obj = ctx.meta[key] + return ctx.invoke(f, obj, *args, **kwargs) + + return update_wrapper(t.cast(F, new_func), f) + + if doc_description is None: + doc_description = f"the {key!r} key from :attr:`click.Context.meta`" + + decorator.__doc__ = ( + f"Decorator that passes {doc_description} as the first argument" + " to the decorated function." + ) + return decorator + + +def _make_command( + f: F, + name: t.Optional[str], + attrs: t.MutableMapping[str, t.Any], + cls: t.Type[Command], +) -> Command: + if isinstance(f, Command): + raise TypeError("Attempted to convert a callback into a command twice.") + + try: + params = f.__click_params__ # type: ignore + params.reverse() + del f.__click_params__ # type: ignore + except AttributeError: + params = [] + + help = attrs.get("help") + + if help is None: + help = inspect.getdoc(f) + else: + help = inspect.cleandoc(help) + + attrs["help"] = help + return cls( + name=name or f.__name__.lower().replace("_", "-"), + callback=f, + params=params, + **attrs, + ) + + +def command( + name: t.Optional[str] = None, + cls: t.Optional[t.Type[Command]] = None, + **attrs: t.Any, +) -> t.Callable[[F], Command]: + r"""Creates a new :class:`Command` and uses the decorated function as + callback. This will also automatically attach all decorated + :func:`option`\s and :func:`argument`\s as parameters to the command. + + The name of the command defaults to the name of the function with + underscores replaced by dashes. If you want to change that, you can + pass the intended name as the first argument. + + All keyword arguments are forwarded to the underlying command class. + + Once decorated the function turns into a :class:`Command` instance + that can be invoked as a command line utility or be attached to a + command :class:`Group`. + + :param name: the name of the command. This defaults to the function + name with underscores replaced by dashes. + :param cls: the command class to instantiate. This defaults to + :class:`Command`. + """ + if cls is None: + cls = Command + + def decorator(f: t.Callable[..., t.Any]) -> Command: + cmd = _make_command(f, name, attrs, cls) # type: ignore + cmd.__doc__ = f.__doc__ + return cmd + + return decorator + + +def group(name: t.Optional[str] = None, **attrs: t.Any) -> t.Callable[[F], Group]: + """Creates a new :class:`Group` with a function as callback. This + works otherwise the same as :func:`command` just that the `cls` + parameter is set to :class:`Group`. + """ + attrs.setdefault("cls", Group) + return t.cast(Group, command(name, **attrs)) + + +def _param_memo(f: FC, param: Parameter) -> None: + if isinstance(f, Command): + f.params.append(param) + else: + if not hasattr(f, "__click_params__"): + f.__click_params__ = [] # type: ignore + + f.__click_params__.append(param) # type: ignore + + +def argument(*param_decls: str, **attrs: t.Any) -> t.Callable[[FC], FC]: + """Attaches an argument to the command. All positional arguments are + passed as parameter declarations to :class:`Argument`; all keyword + arguments are forwarded unchanged (except ``cls``). + This is equivalent to creating an :class:`Argument` instance manually + and attaching it to the :attr:`Command.params` list. + + :param cls: the argument class to instantiate. This defaults to + :class:`Argument`. + """ + + def decorator(f: FC) -> FC: + ArgumentClass = attrs.pop("cls", Argument) + _param_memo(f, ArgumentClass(param_decls, **attrs)) + return f + + return decorator + + +def option(*param_decls: str, **attrs: t.Any) -> t.Callable[[FC], FC]: + """Attaches an option to the command. All positional arguments are + passed as parameter declarations to :class:`Option`; all keyword + arguments are forwarded unchanged (except ``cls``). + This is equivalent to creating an :class:`Option` instance manually + and attaching it to the :attr:`Command.params` list. + + :param cls: the option class to instantiate. This defaults to + :class:`Option`. + """ + + def decorator(f: FC) -> FC: + # Issue 926, copy attrs, so pre-defined options can re-use the same cls= + option_attrs = attrs.copy() + + if "help" in option_attrs: + option_attrs["help"] = inspect.cleandoc(option_attrs["help"]) + OptionClass = option_attrs.pop("cls", Option) + _param_memo(f, OptionClass(param_decls, **option_attrs)) + return f + + return decorator + + +def confirmation_option(*param_decls: str, **kwargs: t.Any) -> t.Callable[[FC], FC]: + """Add a ``--yes`` option which shows a prompt before continuing if + not passed. If the prompt is declined, the program will exit. + + :param param_decls: One or more option names. Defaults to the single + value ``"--yes"``. + :param kwargs: Extra arguments are passed to :func:`option`. + """ + + def callback(ctx: Context, param: Parameter, value: bool) -> None: + if not value: + ctx.abort() + + if not param_decls: + param_decls = ("--yes",) + + kwargs.setdefault("is_flag", True) + kwargs.setdefault("callback", callback) + kwargs.setdefault("expose_value", False) + kwargs.setdefault("prompt", "Do you want to continue?") + kwargs.setdefault("help", "Confirm the action without prompting.") + return option(*param_decls, **kwargs) + + +def password_option(*param_decls: str, **kwargs: t.Any) -> t.Callable[[FC], FC]: + """Add a ``--password`` option which prompts for a password, hiding + input and asking to enter the value again for confirmation. + + :param param_decls: One or more option names. Defaults to the single + value ``"--password"``. + :param kwargs: Extra arguments are passed to :func:`option`. + """ + if not param_decls: + param_decls = ("--password",) + + kwargs.setdefault("prompt", True) + kwargs.setdefault("confirmation_prompt", True) + kwargs.setdefault("hide_input", True) + return option(*param_decls, **kwargs) + + +def version_option( + version: t.Optional[str] = None, + *param_decls: str, + package_name: t.Optional[str] = None, + prog_name: t.Optional[str] = None, + message: t.Optional[str] = None, + **kwargs: t.Any, +) -> t.Callable[[FC], FC]: + """Add a ``--version`` option which immediately prints the version + number and exits the program. + + If ``version`` is not provided, Click will try to detect it using + :func:`importlib.metadata.version` to get the version for the + ``package_name``. On Python < 3.8, the ``importlib_metadata`` + backport must be installed. + + If ``package_name`` is not provided, Click will try to detect it by + inspecting the stack frames. This will be used to detect the + version, so it must match the name of the installed package. + + :param version: The version number to show. If not provided, Click + will try to detect it. + :param param_decls: One or more option names. Defaults to the single + value ``"--version"``. + :param package_name: The package name to detect the version from. If + not provided, Click will try to detect it. + :param prog_name: The name of the CLI to show in the message. If not + provided, it will be detected from the command. + :param message: The message to show. The values ``%(prog)s``, + ``%(package)s``, and ``%(version)s`` are available. Defaults to + ``"%(prog)s, version %(version)s"``. + :param kwargs: Extra arguments are passed to :func:`option`. + :raise RuntimeError: ``version`` could not be detected. + + .. versionchanged:: 8.0 + Add the ``package_name`` parameter, and the ``%(package)s`` + value for messages. + + .. versionchanged:: 8.0 + Use :mod:`importlib.metadata` instead of ``pkg_resources``. The + version is detected based on the package name, not the entry + point name. The Python package name must match the installed + package name, or be passed with ``package_name=``. + """ + if message is None: + message = _("%(prog)s, version %(version)s") + + if version is None and package_name is None: + frame = inspect.currentframe() + f_back = frame.f_back if frame is not None else None + f_globals = f_back.f_globals if f_back is not None else None + # break reference cycle + # https://docs.python.org/3/library/inspect.html#the-interpreter-stack + del frame + + if f_globals is not None: + package_name = f_globals.get("__name__") + + if package_name == "__main__": + package_name = f_globals.get("__package__") + + if package_name: + package_name = package_name.partition(".")[0] + + def callback(ctx: Context, param: Parameter, value: bool) -> None: + if not value or ctx.resilient_parsing: + return + + nonlocal prog_name + nonlocal version + + if prog_name is None: + prog_name = ctx.find_root().info_name + + if version is None and package_name is not None: + metadata: t.Optional[types.ModuleType] + + try: + from importlib import metadata # type: ignore + except ImportError: + # Python < 3.8 + import importlib_metadata as metadata # type: ignore + + try: + version = metadata.version(package_name) # type: ignore + except metadata.PackageNotFoundError: # type: ignore + raise RuntimeError( + f"{package_name!r} is not installed. Try passing" + " 'package_name' instead." + ) from None + + if version is None: + raise RuntimeError( + f"Could not determine the version for {package_name!r} automatically." + ) + + echo( + t.cast(str, message) + % {"prog": prog_name, "package": package_name, "version": version}, + color=ctx.color, + ) + ctx.exit() + + if not param_decls: + param_decls = ("--version",) + + kwargs.setdefault("is_flag", True) + kwargs.setdefault("expose_value", False) + kwargs.setdefault("is_eager", True) + kwargs.setdefault("help", _("Show the version and exit.")) + kwargs["callback"] = callback + return option(*param_decls, **kwargs) + + +def help_option(*param_decls: str, **kwargs: t.Any) -> t.Callable[[FC], FC]: + """Add a ``--help`` option which immediately prints the help page + and exits the program. + + This is usually unnecessary, as the ``--help`` option is added to + each command automatically unless ``add_help_option=False`` is + passed. + + :param param_decls: One or more option names. Defaults to the single + value ``"--help"``. + :param kwargs: Extra arguments are passed to :func:`option`. + """ + + def callback(ctx: Context, param: Parameter, value: bool) -> None: + if not value or ctx.resilient_parsing: + return + + echo(ctx.get_help(), color=ctx.color) + ctx.exit() + + if not param_decls: + param_decls = ("--help",) + + kwargs.setdefault("is_flag", True) + kwargs.setdefault("expose_value", False) + kwargs.setdefault("is_eager", True) + kwargs.setdefault("help", _("Show this message and exit.")) + kwargs["callback"] = callback + return option(*param_decls, **kwargs) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/exceptions.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/exceptions.py new file mode 100644 index 00000000..9e20b3eb --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/exceptions.py @@ -0,0 +1,287 @@ +import os +import typing as t +from gettext import gettext as _ +from gettext import ngettext + +from ._compat import get_text_stderr +from .utils import echo + +if t.TYPE_CHECKING: + from .core import Context + from .core import Parameter + + +def _join_param_hints( + param_hint: t.Optional[t.Union[t.Sequence[str], str]] +) -> t.Optional[str]: + if param_hint is not None and not isinstance(param_hint, str): + return " / ".join(repr(x) for x in param_hint) + + return param_hint + + +class ClickException(Exception): + """An exception that Click can handle and show to the user.""" + + #: The exit code for this exception. + exit_code = 1 + + def __init__(self, message: str) -> None: + super().__init__(message) + self.message = message + + def format_message(self) -> str: + return self.message + + def __str__(self) -> str: + return self.message + + def show(self, file: t.Optional[t.IO] = None) -> None: + if file is None: + file = get_text_stderr() + + echo(_("Error: {message}").format(message=self.format_message()), file=file) + + +class UsageError(ClickException): + """An internal exception that signals a usage error. This typically + aborts any further handling. + + :param message: the error message to display. + :param ctx: optionally the context that caused this error. Click will + fill in the context automatically in some situations. + """ + + exit_code = 2 + + def __init__(self, message: str, ctx: t.Optional["Context"] = None) -> None: + super().__init__(message) + self.ctx = ctx + self.cmd = self.ctx.command if self.ctx else None + + def show(self, file: t.Optional[t.IO] = None) -> None: + if file is None: + file = get_text_stderr() + color = None + hint = "" + if ( + self.ctx is not None + and self.ctx.command.get_help_option(self.ctx) is not None + ): + hint = _("Try '{command} {option}' for help.").format( + command=self.ctx.command_path, option=self.ctx.help_option_names[0] + ) + hint = f"{hint}\n" + if self.ctx is not None: + color = self.ctx.color + echo(f"{self.ctx.get_usage()}\n{hint}", file=file, color=color) + echo( + _("Error: {message}").format(message=self.format_message()), + file=file, + color=color, + ) + + +class BadParameter(UsageError): + """An exception that formats out a standardized error message for a + bad parameter. This is useful when thrown from a callback or type as + Click will attach contextual information to it (for instance, which + parameter it is). + + .. versionadded:: 2.0 + + :param param: the parameter object that caused this error. This can + be left out, and Click will attach this info itself + if possible. + :param param_hint: a string that shows up as parameter name. This + can be used as alternative to `param` in cases + where custom validation should happen. If it is + a string it's used as such, if it's a list then + each item is quoted and separated. + """ + + def __init__( + self, + message: str, + ctx: t.Optional["Context"] = None, + param: t.Optional["Parameter"] = None, + param_hint: t.Optional[str] = None, + ) -> None: + super().__init__(message, ctx) + self.param = param + self.param_hint = param_hint + + def format_message(self) -> str: + if self.param_hint is not None: + param_hint = self.param_hint + elif self.param is not None: + param_hint = self.param.get_error_hint(self.ctx) # type: ignore + else: + return _("Invalid value: {message}").format(message=self.message) + + return _("Invalid value for {param_hint}: {message}").format( + param_hint=_join_param_hints(param_hint), message=self.message + ) + + +class MissingParameter(BadParameter): + """Raised if click required an option or argument but it was not + provided when invoking the script. + + .. versionadded:: 4.0 + + :param param_type: a string that indicates the type of the parameter. + The default is to inherit the parameter type from + the given `param`. Valid values are ``'parameter'``, + ``'option'`` or ``'argument'``. + """ + + def __init__( + self, + message: t.Optional[str] = None, + ctx: t.Optional["Context"] = None, + param: t.Optional["Parameter"] = None, + param_hint: t.Optional[str] = None, + param_type: t.Optional[str] = None, + ) -> None: + super().__init__(message or "", ctx, param, param_hint) + self.param_type = param_type + + def format_message(self) -> str: + if self.param_hint is not None: + param_hint: t.Optional[str] = self.param_hint + elif self.param is not None: + param_hint = self.param.get_error_hint(self.ctx) # type: ignore + else: + param_hint = None + + param_hint = _join_param_hints(param_hint) + param_hint = f" {param_hint}" if param_hint else "" + + param_type = self.param_type + if param_type is None and self.param is not None: + param_type = self.param.param_type_name + + msg = self.message + if self.param is not None: + msg_extra = self.param.type.get_missing_message(self.param) + if msg_extra: + if msg: + msg += f". {msg_extra}" + else: + msg = msg_extra + + msg = f" {msg}" if msg else "" + + # Translate param_type for known types. + if param_type == "argument": + missing = _("Missing argument") + elif param_type == "option": + missing = _("Missing option") + elif param_type == "parameter": + missing = _("Missing parameter") + else: + missing = _("Missing {param_type}").format(param_type=param_type) + + return f"{missing}{param_hint}.{msg}" + + def __str__(self) -> str: + if not self.message: + param_name = self.param.name if self.param else None + return _("Missing parameter: {param_name}").format(param_name=param_name) + else: + return self.message + + +class NoSuchOption(UsageError): + """Raised if click attempted to handle an option that does not + exist. + + .. versionadded:: 4.0 + """ + + def __init__( + self, + option_name: str, + message: t.Optional[str] = None, + possibilities: t.Optional[t.Sequence[str]] = None, + ctx: t.Optional["Context"] = None, + ) -> None: + if message is None: + message = _("No such option: {name}").format(name=option_name) + + super().__init__(message, ctx) + self.option_name = option_name + self.possibilities = possibilities + + def format_message(self) -> str: + if not self.possibilities: + return self.message + + possibility_str = ", ".join(sorted(self.possibilities)) + suggest = ngettext( + "Did you mean {possibility}?", + "(Possible options: {possibilities})", + len(self.possibilities), + ).format(possibility=possibility_str, possibilities=possibility_str) + return f"{self.message} {suggest}" + + +class BadOptionUsage(UsageError): + """Raised if an option is generally supplied but the use of the option + was incorrect. This is for instance raised if the number of arguments + for an option is not correct. + + .. versionadded:: 4.0 + + :param option_name: the name of the option being used incorrectly. + """ + + def __init__( + self, option_name: str, message: str, ctx: t.Optional["Context"] = None + ) -> None: + super().__init__(message, ctx) + self.option_name = option_name + + +class BadArgumentUsage(UsageError): + """Raised if an argument is generally supplied but the use of the argument + was incorrect. This is for instance raised if the number of values + for an argument is not correct. + + .. versionadded:: 6.0 + """ + + +class FileError(ClickException): + """Raised if a file cannot be opened.""" + + def __init__(self, filename: str, hint: t.Optional[str] = None) -> None: + if hint is None: + hint = _("unknown error") + + super().__init__(hint) + self.ui_filename = os.fsdecode(filename) + self.filename = filename + + def format_message(self) -> str: + return _("Could not open file {filename!r}: {message}").format( + filename=self.ui_filename, message=self.message + ) + + +class Abort(RuntimeError): + """An internal signalling exception that signals Click to abort.""" + + +class Exit(RuntimeError): + """An exception that indicates that the application should exit with some + status code. + + :param code: the status code to exit with. + """ + + __slots__ = ("exit_code",) + + def __init__(self, code: int = 0) -> None: + self.exit_code = code diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/formatting.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/formatting.py new file mode 100644 index 00000000..ddd2a2f8 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/formatting.py @@ -0,0 +1,301 @@ +import typing as t +from contextlib import contextmanager +from gettext import gettext as _ + +from ._compat import term_len +from .parser import split_opt + +# Can force a width. This is used by the test system +FORCED_WIDTH: t.Optional[int] = None + + +def measure_table(rows: t.Iterable[t.Tuple[str, str]]) -> t.Tuple[int, ...]: + widths: t.Dict[int, int] = {} + + for row in rows: + for idx, col in enumerate(row): + widths[idx] = max(widths.get(idx, 0), term_len(col)) + + return tuple(y for x, y in sorted(widths.items())) + + +def iter_rows( + rows: t.Iterable[t.Tuple[str, str]], col_count: int +) -> t.Iterator[t.Tuple[str, ...]]: + for row in rows: + yield row + ("",) * (col_count - len(row)) + + +def wrap_text( + text: str, + width: int = 78, + initial_indent: str = "", + subsequent_indent: str = "", + preserve_paragraphs: bool = False, +) -> str: + """A helper function that intelligently wraps text. By default, it + assumes that it operates on a single paragraph of text but if the + `preserve_paragraphs` parameter is provided it will intelligently + handle paragraphs (defined by two empty lines). + + If paragraphs are handled, a paragraph can be prefixed with an empty + line containing the ``\\b`` character (``\\x08``) to indicate that + no rewrapping should happen in that block. + + :param text: the text that should be rewrapped. + :param width: the maximum width for the text. + :param initial_indent: the initial indent that should be placed on the + first line as a string. + :param subsequent_indent: the indent string that should be placed on + each consecutive line. + :param preserve_paragraphs: if this flag is set then the wrapping will + intelligently handle paragraphs. + """ + from ._textwrap import TextWrapper + + text = text.expandtabs() + wrapper = TextWrapper( + width, + initial_indent=initial_indent, + subsequent_indent=subsequent_indent, + replace_whitespace=False, + ) + if not preserve_paragraphs: + return wrapper.fill(text) + + p: t.List[t.Tuple[int, bool, str]] = [] + buf: t.List[str] = [] + indent = None + + def _flush_par() -> None: + if not buf: + return + if buf[0].strip() == "\b": + p.append((indent or 0, True, "\n".join(buf[1:]))) + else: + p.append((indent or 0, False, " ".join(buf))) + del buf[:] + + for line in text.splitlines(): + if not line: + _flush_par() + indent = None + else: + if indent is None: + orig_len = term_len(line) + line = line.lstrip() + indent = orig_len - term_len(line) + buf.append(line) + _flush_par() + + rv = [] + for indent, raw, text in p: + with wrapper.extra_indent(" " * indent): + if raw: + rv.append(wrapper.indent_only(text)) + else: + rv.append(wrapper.fill(text)) + + return "\n\n".join(rv) + + +class HelpFormatter: + """This class helps with formatting text-based help pages. It's + usually just needed for very special internal cases, but it's also + exposed so that developers can write their own fancy outputs. + + At present, it always writes into memory. + + :param indent_increment: the additional increment for each level. + :param width: the width for the text. This defaults to the terminal + width clamped to a maximum of 78. + """ + + def __init__( + self, + indent_increment: int = 2, + width: t.Optional[int] = None, + max_width: t.Optional[int] = None, + ) -> None: + import shutil + + self.indent_increment = indent_increment + if max_width is None: + max_width = 80 + if width is None: + width = FORCED_WIDTH + if width is None: + width = max(min(shutil.get_terminal_size().columns, max_width) - 2, 50) + self.width = width + self.current_indent = 0 + self.buffer: t.List[str] = [] + + def write(self, string: str) -> None: + """Writes a unicode string into the internal buffer.""" + self.buffer.append(string) + + def indent(self) -> None: + """Increases the indentation.""" + self.current_indent += self.indent_increment + + def dedent(self) -> None: + """Decreases the indentation.""" + self.current_indent -= self.indent_increment + + def write_usage( + self, prog: str, args: str = "", prefix: t.Optional[str] = None + ) -> None: + """Writes a usage line into the buffer. + + :param prog: the program name. + :param args: whitespace separated list of arguments. + :param prefix: The prefix for the first line. Defaults to + ``"Usage: "``. + """ + if prefix is None: + prefix = f"{_('Usage:')} " + + usage_prefix = f"{prefix:>{self.current_indent}}{prog} " + text_width = self.width - self.current_indent + + if text_width >= (term_len(usage_prefix) + 20): + # The arguments will fit to the right of the prefix. + indent = " " * term_len(usage_prefix) + self.write( + wrap_text( + args, + text_width, + initial_indent=usage_prefix, + subsequent_indent=indent, + ) + ) + else: + # The prefix is too long, put the arguments on the next line. + self.write(usage_prefix) + self.write("\n") + indent = " " * (max(self.current_indent, term_len(prefix)) + 4) + self.write( + wrap_text( + args, text_width, initial_indent=indent, subsequent_indent=indent + ) + ) + + self.write("\n") + + def write_heading(self, heading: str) -> None: + """Writes a heading into the buffer.""" + self.write(f"{'':>{self.current_indent}}{heading}:\n") + + def write_paragraph(self) -> None: + """Writes a paragraph into the buffer.""" + if self.buffer: + self.write("\n") + + def write_text(self, text: str) -> None: + """Writes re-indented text into the buffer. This rewraps and + preserves paragraphs. + """ + indent = " " * self.current_indent + self.write( + wrap_text( + text, + self.width, + initial_indent=indent, + subsequent_indent=indent, + preserve_paragraphs=True, + ) + ) + self.write("\n") + + def write_dl( + self, + rows: t.Sequence[t.Tuple[str, str]], + col_max: int = 30, + col_spacing: int = 2, + ) -> None: + """Writes a definition list into the buffer. This is how options + and commands are usually formatted. + + :param rows: a list of two item tuples for the terms and values. + :param col_max: the maximum width of the first column. + :param col_spacing: the number of spaces between the first and + second column. + """ + rows = list(rows) + widths = measure_table(rows) + if len(widths) != 2: + raise TypeError("Expected two columns for definition list") + + first_col = min(widths[0], col_max) + col_spacing + + for first, second in iter_rows(rows, len(widths)): + self.write(f"{'':>{self.current_indent}}{first}") + if not second: + self.write("\n") + continue + if term_len(first) <= first_col - col_spacing: + self.write(" " * (first_col - term_len(first))) + else: + self.write("\n") + self.write(" " * (first_col + self.current_indent)) + + text_width = max(self.width - first_col - 2, 10) + wrapped_text = wrap_text(second, text_width, preserve_paragraphs=True) + lines = wrapped_text.splitlines() + + if lines: + self.write(f"{lines[0]}\n") + + for line in lines[1:]: + self.write(f"{'':>{first_col + self.current_indent}}{line}\n") + else: + self.write("\n") + + @contextmanager + def section(self, name: str) -> t.Iterator[None]: + """Helpful context manager that writes a paragraph, a heading, + and the indents. + + :param name: the section name that is written as heading. + """ + self.write_paragraph() + self.write_heading(name) + self.indent() + try: + yield + finally: + self.dedent() + + @contextmanager + def indentation(self) -> t.Iterator[None]: + """A context manager that increases the indentation.""" + self.indent() + try: + yield + finally: + self.dedent() + + def getvalue(self) -> str: + """Returns the buffer contents.""" + return "".join(self.buffer) + + +def join_options(options: t.Sequence[str]) -> t.Tuple[str, bool]: + """Given a list of option strings this joins them in the most appropriate + way and returns them in the form ``(formatted_string, + any_prefix_is_slash)`` where the second item in the tuple is a flag that + indicates if any of the option prefixes was a slash. + """ + rv = [] + any_prefix_is_slash = False + + for opt in options: + prefix = split_opt(opt)[0] + + if prefix == "/": + any_prefix_is_slash = True + + rv.append((len(prefix), opt)) + + rv.sort(key=lambda x: x[0]) + return ", ".join(x[1] for x in rv), any_prefix_is_slash diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/globals.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/globals.py new file mode 100644 index 00000000..a7b0c931 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/globals.py @@ -0,0 +1,69 @@ +import typing +import typing as t +from threading import local + +if t.TYPE_CHECKING: + import typing_extensions as te + from .core import Context + +_local = local() + + +@typing.overload +def get_current_context(silent: "te.Literal[False]" = False) -> "Context": + ... + + +@typing.overload +def get_current_context(silent: bool = ...) -> t.Optional["Context"]: + ... + + +def get_current_context(silent: bool = False) -> t.Optional["Context"]: + """Returns the current click context. This can be used as a way to + access the current context object from anywhere. This is a more implicit + alternative to the :func:`pass_context` decorator. This function is + primarily useful for helpers such as :func:`echo` which might be + interested in changing its behavior based on the current context. + + To push the current context, :meth:`Context.scope` can be used. + + .. versionadded:: 5.0 + + :param silent: if set to `True` the return value is `None` if no context + is available. The default behavior is to raise a + :exc:`RuntimeError`. + """ + try: + return t.cast("Context", _local.stack[-1]) + except (AttributeError, IndexError) as e: + if not silent: + raise RuntimeError("There is no active click context.") from e + + return None + + +def push_context(ctx: "Context") -> None: + """Pushes a new context to the current stack.""" + _local.__dict__.setdefault("stack", []).append(ctx) + + +def pop_context() -> None: + """Removes the top level from the stack.""" + _local.stack.pop() + + +def resolve_color_default(color: t.Optional[bool] = None) -> t.Optional[bool]: + """Internal helper to get the default value of the color flag. If a + value is passed it's returned unchanged, otherwise it's looked up from + the current context. + """ + if color is not None: + return color + + ctx = get_current_context(silent=True) + + if ctx is not None: + return ctx.color + + return None diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/parser.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/parser.py new file mode 100644 index 00000000..2d5a2ed7 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/parser.py @@ -0,0 +1,529 @@ +""" +This module started out as largely a copy paste from the stdlib's +optparse module with the features removed that we do not need from +optparse because we implement them in Click on a higher level (for +instance type handling, help formatting and a lot more). + +The plan is to remove more and more from here over time. + +The reason this is a different module and not optparse from the stdlib +is that there are differences in 2.x and 3.x about the error messages +generated and optparse in the stdlib uses gettext for no good reason +and might cause us issues. + +Click uses parts of optparse written by Gregory P. Ward and maintained +by the Python Software Foundation. This is limited to code in parser.py. + +Copyright 2001-2006 Gregory P. Ward. All rights reserved. +Copyright 2002-2006 Python Software Foundation. All rights reserved. +""" +# This code uses parts of optparse written by Gregory P. Ward and +# maintained by the Python Software Foundation. +# Copyright 2001-2006 Gregory P. Ward +# Copyright 2002-2006 Python Software Foundation +import typing as t +from collections import deque +from gettext import gettext as _ +from gettext import ngettext + +from .exceptions import BadArgumentUsage +from .exceptions import BadOptionUsage +from .exceptions import NoSuchOption +from .exceptions import UsageError + +if t.TYPE_CHECKING: + import typing_extensions as te + from .core import Argument as CoreArgument + from .core import Context + from .core import Option as CoreOption + from .core import Parameter as CoreParameter + +V = t.TypeVar("V") + +# Sentinel value that indicates an option was passed as a flag without a +# value but is not a flag option. Option.consume_value uses this to +# prompt or use the flag_value. +_flag_needs_value = object() + + +def _unpack_args( + args: t.Sequence[str], nargs_spec: t.Sequence[int] +) -> t.Tuple[t.Sequence[t.Union[str, t.Sequence[t.Optional[str]], None]], t.List[str]]: + """Given an iterable of arguments and an iterable of nargs specifications, + it returns a tuple with all the unpacked arguments at the first index + and all remaining arguments as the second. + + The nargs specification is the number of arguments that should be consumed + or `-1` to indicate that this position should eat up all the remainders. + + Missing items are filled with `None`. + """ + args = deque(args) + nargs_spec = deque(nargs_spec) + rv: t.List[t.Union[str, t.Tuple[t.Optional[str], ...], None]] = [] + spos: t.Optional[int] = None + + def _fetch(c: "te.Deque[V]") -> t.Optional[V]: + try: + if spos is None: + return c.popleft() + else: + return c.pop() + except IndexError: + return None + + while nargs_spec: + nargs = _fetch(nargs_spec) + + if nargs is None: + continue + + if nargs == 1: + rv.append(_fetch(args)) + elif nargs > 1: + x = [_fetch(args) for _ in range(nargs)] + + # If we're reversed, we're pulling in the arguments in reverse, + # so we need to turn them around. + if spos is not None: + x.reverse() + + rv.append(tuple(x)) + elif nargs < 0: + if spos is not None: + raise TypeError("Cannot have two nargs < 0") + + spos = len(rv) + rv.append(None) + + # spos is the position of the wildcard (star). If it's not `None`, + # we fill it with the remainder. + if spos is not None: + rv[spos] = tuple(args) + args = [] + rv[spos + 1 :] = reversed(rv[spos + 1 :]) + + return tuple(rv), list(args) + + +def split_opt(opt: str) -> t.Tuple[str, str]: + first = opt[:1] + if first.isalnum(): + return "", opt + if opt[1:2] == first: + return opt[:2], opt[2:] + return first, opt[1:] + + +def normalize_opt(opt: str, ctx: t.Optional["Context"]) -> str: + if ctx is None or ctx.token_normalize_func is None: + return opt + prefix, opt = split_opt(opt) + return f"{prefix}{ctx.token_normalize_func(opt)}" + + +def split_arg_string(string: str) -> t.List[str]: + """Split an argument string as with :func:`shlex.split`, but don't + fail if the string is incomplete. Ignores a missing closing quote or + incomplete escape sequence and uses the partial token as-is. + + .. code-block:: python + + split_arg_string("example 'my file") + ["example", "my file"] + + split_arg_string("example my\\") + ["example", "my"] + + :param string: String to split. + """ + import shlex + + lex = shlex.shlex(string, posix=True) + lex.whitespace_split = True + lex.commenters = "" + out = [] + + try: + for token in lex: + out.append(token) + except ValueError: + # Raised when end-of-string is reached in an invalid state. Use + # the partial token as-is. The quote or escape character is in + # lex.state, not lex.token. + out.append(lex.token) + + return out + + +class Option: + def __init__( + self, + obj: "CoreOption", + opts: t.Sequence[str], + dest: t.Optional[str], + action: t.Optional[str] = None, + nargs: int = 1, + const: t.Optional[t.Any] = None, + ): + self._short_opts = [] + self._long_opts = [] + self.prefixes = set() + + for opt in opts: + prefix, value = split_opt(opt) + if not prefix: + raise ValueError(f"Invalid start character for option ({opt})") + self.prefixes.add(prefix[0]) + if len(prefix) == 1 and len(value) == 1: + self._short_opts.append(opt) + else: + self._long_opts.append(opt) + self.prefixes.add(prefix) + + if action is None: + action = "store" + + self.dest = dest + self.action = action + self.nargs = nargs + self.const = const + self.obj = obj + + @property + def takes_value(self) -> bool: + return self.action in ("store", "append") + + def process(self, value: str, state: "ParsingState") -> None: + if self.action == "store": + state.opts[self.dest] = value # type: ignore + elif self.action == "store_const": + state.opts[self.dest] = self.const # type: ignore + elif self.action == "append": + state.opts.setdefault(self.dest, []).append(value) # type: ignore + elif self.action == "append_const": + state.opts.setdefault(self.dest, []).append(self.const) # type: ignore + elif self.action == "count": + state.opts[self.dest] = state.opts.get(self.dest, 0) + 1 # type: ignore + else: + raise ValueError(f"unknown action '{self.action}'") + state.order.append(self.obj) + + +class Argument: + def __init__(self, obj: "CoreArgument", dest: t.Optional[str], nargs: int = 1): + self.dest = dest + self.nargs = nargs + self.obj = obj + + def process( + self, + value: t.Union[t.Optional[str], t.Sequence[t.Optional[str]]], + state: "ParsingState", + ) -> None: + if self.nargs > 1: + assert value is not None + holes = sum(1 for x in value if x is None) + if holes == len(value): + value = None + elif holes != 0: + raise BadArgumentUsage( + _("Argument {name!r} takes {nargs} values.").format( + name=self.dest, nargs=self.nargs + ) + ) + + if self.nargs == -1 and self.obj.envvar is not None and value == (): + # Replace empty tuple with None so that a value from the + # environment may be tried. + value = None + + state.opts[self.dest] = value # type: ignore + state.order.append(self.obj) + + +class ParsingState: + def __init__(self, rargs: t.List[str]) -> None: + self.opts: t.Dict[str, t.Any] = {} + self.largs: t.List[str] = [] + self.rargs = rargs + self.order: t.List["CoreParameter"] = [] + + +class OptionParser: + """The option parser is an internal class that is ultimately used to + parse options and arguments. It's modelled after optparse and brings + a similar but vastly simplified API. It should generally not be used + directly as the high level Click classes wrap it for you. + + It's not nearly as extensible as optparse or argparse as it does not + implement features that are implemented on a higher level (such as + types or defaults). + + :param ctx: optionally the :class:`~click.Context` where this parser + should go with. + """ + + def __init__(self, ctx: t.Optional["Context"] = None) -> None: + #: The :class:`~click.Context` for this parser. This might be + #: `None` for some advanced use cases. + self.ctx = ctx + #: This controls how the parser deals with interspersed arguments. + #: If this is set to `False`, the parser will stop on the first + #: non-option. Click uses this to implement nested subcommands + #: safely. + self.allow_interspersed_args = True + #: This tells the parser how to deal with unknown options. By + #: default it will error out (which is sensible), but there is a + #: second mode where it will ignore it and continue processing + #: after shifting all the unknown options into the resulting args. + self.ignore_unknown_options = False + + if ctx is not None: + self.allow_interspersed_args = ctx.allow_interspersed_args + self.ignore_unknown_options = ctx.ignore_unknown_options + + self._short_opt: t.Dict[str, Option] = {} + self._long_opt: t.Dict[str, Option] = {} + self._opt_prefixes = {"-", "--"} + self._args: t.List[Argument] = [] + + def add_option( + self, + obj: "CoreOption", + opts: t.Sequence[str], + dest: t.Optional[str], + action: t.Optional[str] = None, + nargs: int = 1, + const: t.Optional[t.Any] = None, + ) -> None: + """Adds a new option named `dest` to the parser. The destination + is not inferred (unlike with optparse) and needs to be explicitly + provided. Action can be any of ``store``, ``store_const``, + ``append``, ``append_const`` or ``count``. + + The `obj` can be used to identify the option in the order list + that is returned from the parser. + """ + opts = [normalize_opt(opt, self.ctx) for opt in opts] + option = Option(obj, opts, dest, action=action, nargs=nargs, const=const) + self._opt_prefixes.update(option.prefixes) + for opt in option._short_opts: + self._short_opt[opt] = option + for opt in option._long_opts: + self._long_opt[opt] = option + + def add_argument( + self, obj: "CoreArgument", dest: t.Optional[str], nargs: int = 1 + ) -> None: + """Adds a positional argument named `dest` to the parser. + + The `obj` can be used to identify the option in the order list + that is returned from the parser. + """ + self._args.append(Argument(obj, dest=dest, nargs=nargs)) + + def parse_args( + self, args: t.List[str] + ) -> t.Tuple[t.Dict[str, t.Any], t.List[str], t.List["CoreParameter"]]: + """Parses positional arguments and returns ``(values, args, order)`` + for the parsed options and arguments as well as the leftover + arguments if there are any. The order is a list of objects as they + appear on the command line. If arguments appear multiple times they + will be memorized multiple times as well. + """ + state = ParsingState(args) + try: + self._process_args_for_options(state) + self._process_args_for_args(state) + except UsageError: + if self.ctx is None or not self.ctx.resilient_parsing: + raise + return state.opts, state.largs, state.order + + def _process_args_for_args(self, state: ParsingState) -> None: + pargs, args = _unpack_args( + state.largs + state.rargs, [x.nargs for x in self._args] + ) + + for idx, arg in enumerate(self._args): + arg.process(pargs[idx], state) + + state.largs = args + state.rargs = [] + + def _process_args_for_options(self, state: ParsingState) -> None: + while state.rargs: + arg = state.rargs.pop(0) + arglen = len(arg) + # Double dashes always handled explicitly regardless of what + # prefixes are valid. + if arg == "--": + return + elif arg[:1] in self._opt_prefixes and arglen > 1: + self._process_opts(arg, state) + elif self.allow_interspersed_args: + state.largs.append(arg) + else: + state.rargs.insert(0, arg) + return + + # Say this is the original argument list: + # [arg0, arg1, ..., arg(i-1), arg(i), arg(i+1), ..., arg(N-1)] + # ^ + # (we are about to process arg(i)). + # + # Then rargs is [arg(i), ..., arg(N-1)] and largs is a *subset* of + # [arg0, ..., arg(i-1)] (any options and their arguments will have + # been removed from largs). + # + # The while loop will usually consume 1 or more arguments per pass. + # If it consumes 1 (eg. arg is an option that takes no arguments), + # then after _process_arg() is done the situation is: + # + # largs = subset of [arg0, ..., arg(i)] + # rargs = [arg(i+1), ..., arg(N-1)] + # + # If allow_interspersed_args is false, largs will always be + # *empty* -- still a subset of [arg0, ..., arg(i-1)], but + # not a very interesting subset! + + def _match_long_opt( + self, opt: str, explicit_value: t.Optional[str], state: ParsingState + ) -> None: + if opt not in self._long_opt: + from difflib import get_close_matches + + possibilities = get_close_matches(opt, self._long_opt) + raise NoSuchOption(opt, possibilities=possibilities, ctx=self.ctx) + + option = self._long_opt[opt] + if option.takes_value: + # At this point it's safe to modify rargs by injecting the + # explicit value, because no exception is raised in this + # branch. This means that the inserted value will be fully + # consumed. + if explicit_value is not None: + state.rargs.insert(0, explicit_value) + + value = self._get_value_from_state(opt, option, state) + + elif explicit_value is not None: + raise BadOptionUsage( + opt, _("Option {name!r} does not take a value.").format(name=opt) + ) + + else: + value = None + + option.process(value, state) + + def _match_short_opt(self, arg: str, state: ParsingState) -> None: + stop = False + i = 1 + prefix = arg[0] + unknown_options = [] + + for ch in arg[1:]: + opt = normalize_opt(f"{prefix}{ch}", self.ctx) + option = self._short_opt.get(opt) + i += 1 + + if not option: + if self.ignore_unknown_options: + unknown_options.append(ch) + continue + raise NoSuchOption(opt, ctx=self.ctx) + if option.takes_value: + # Any characters left in arg? Pretend they're the + # next arg, and stop consuming characters of arg. + if i < len(arg): + state.rargs.insert(0, arg[i:]) + stop = True + + value = self._get_value_from_state(opt, option, state) + + else: + value = None + + option.process(value, state) + + if stop: + break + + # If we got any unknown options we re-combinate the string of the + # remaining options and re-attach the prefix, then report that + # to the state as new larg. This way there is basic combinatorics + # that can be achieved while still ignoring unknown arguments. + if self.ignore_unknown_options and unknown_options: + state.largs.append(f"{prefix}{''.join(unknown_options)}") + + def _get_value_from_state( + self, option_name: str, option: Option, state: ParsingState + ) -> t.Any: + nargs = option.nargs + + if len(state.rargs) < nargs: + if option.obj._flag_needs_value: + # Option allows omitting the value. + value = _flag_needs_value + else: + raise BadOptionUsage( + option_name, + ngettext( + "Option {name!r} requires an argument.", + "Option {name!r} requires {nargs} arguments.", + nargs, + ).format(name=option_name, nargs=nargs), + ) + elif nargs == 1: + next_rarg = state.rargs[0] + + if ( + option.obj._flag_needs_value + and isinstance(next_rarg, str) + and next_rarg[:1] in self._opt_prefixes + and len(next_rarg) > 1 + ): + # The next arg looks like the start of an option, don't + # use it as the value if omitting the value is allowed. + value = _flag_needs_value + else: + value = state.rargs.pop(0) + else: + value = tuple(state.rargs[:nargs]) + del state.rargs[:nargs] + + return value + + def _process_opts(self, arg: str, state: ParsingState) -> None: + explicit_value = None + # Long option handling happens in two parts. The first part is + # supporting explicitly attached values. In any case, we will try + # to long match the option first. + if "=" in arg: + long_opt, explicit_value = arg.split("=", 1) + else: + long_opt = arg + norm_long_opt = normalize_opt(long_opt, self.ctx) + + # At this point we will match the (assumed) long option through + # the long option matching code. Note that this allows options + # like "-foo" to be matched as long options. + try: + self._match_long_opt(norm_long_opt, explicit_value, state) + except NoSuchOption: + # At this point the long option matching failed, and we need + # to try with short options. However there is a special rule + # which says, that if we have a two character options prefix + # (applies to "--foo" for instance), we do not dispatch to the + # short option code and will instead raise the no option + # error. + if arg[:2] not in self._opt_prefixes: + self._match_short_opt(arg, state) + return + + if not self.ignore_unknown_options: + raise + + state.largs.append(arg) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/py.typed b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/py.typed new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/shell_completion.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/shell_completion.py new file mode 100644 index 00000000..cad080da --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/shell_completion.py @@ -0,0 +1,581 @@ +import os +import re +import typing as t +from gettext import gettext as _ + +from .core import Argument +from .core import BaseCommand +from .core import Context +from .core import MultiCommand +from .core import Option +from .core import Parameter +from .core import ParameterSource +from .parser import split_arg_string +from .utils import echo + + +def shell_complete( + cli: BaseCommand, + ctx_args: t.Dict[str, t.Any], + prog_name: str, + complete_var: str, + instruction: str, +) -> int: + """Perform shell completion for the given CLI program. + + :param cli: Command being called. + :param ctx_args: Extra arguments to pass to + ``cli.make_context``. + :param prog_name: Name of the executable in the shell. + :param complete_var: Name of the environment variable that holds + the completion instruction. + :param instruction: Value of ``complete_var`` with the completion + instruction and shell, in the form ``instruction_shell``. + :return: Status code to exit with. + """ + shell, _, instruction = instruction.partition("_") + comp_cls = get_completion_class(shell) + + if comp_cls is None: + return 1 + + comp = comp_cls(cli, ctx_args, prog_name, complete_var) + + if instruction == "source": + echo(comp.source()) + return 0 + + if instruction == "complete": + echo(comp.complete()) + return 0 + + return 1 + + +class CompletionItem: + """Represents a completion value and metadata about the value. The + default metadata is ``type`` to indicate special shell handling, + and ``help`` if a shell supports showing a help string next to the + value. + + Arbitrary parameters can be passed when creating the object, and + accessed using ``item.attr``. If an attribute wasn't passed, + accessing it returns ``None``. + + :param value: The completion suggestion. + :param type: Tells the shell script to provide special completion + support for the type. Click uses ``"dir"`` and ``"file"``. + :param help: String shown next to the value if supported. + :param kwargs: Arbitrary metadata. The built-in implementations + don't use this, but custom type completions paired with custom + shell support could use it. + """ + + __slots__ = ("value", "type", "help", "_info") + + def __init__( + self, + value: t.Any, + type: str = "plain", + help: t.Optional[str] = None, + **kwargs: t.Any, + ) -> None: + self.value = value + self.type = type + self.help = help + self._info = kwargs + + def __getattr__(self, name: str) -> t.Any: + return self._info.get(name) + + +# Only Bash >= 4.4 has the nosort option. +_SOURCE_BASH = """\ +%(complete_func)s() { + local IFS=$'\\n' + local response + + response=$(env COMP_WORDS="${COMP_WORDS[*]}" COMP_CWORD=$COMP_CWORD \ +%(complete_var)s=bash_complete $1) + + for completion in $response; do + IFS=',' read type value <<< "$completion" + + if [[ $type == 'dir' ]]; then + COMREPLY=() + compopt -o dirnames + elif [[ $type == 'file' ]]; then + COMREPLY=() + compopt -o default + elif [[ $type == 'plain' ]]; then + COMPREPLY+=($value) + fi + done + + return 0 +} + +%(complete_func)s_setup() { + complete -o nosort -F %(complete_func)s %(prog_name)s +} + +%(complete_func)s_setup; +""" + +_SOURCE_ZSH = """\ +#compdef %(prog_name)s + +%(complete_func)s() { + local -a completions + local -a completions_with_descriptions + local -a response + (( ! $+commands[%(prog_name)s] )) && return 1 + + response=("${(@f)$(env COMP_WORDS="${words[*]}" COMP_CWORD=$((CURRENT-1)) \ +%(complete_var)s=zsh_complete %(prog_name)s)}") + + for type key descr in ${response}; do + if [[ "$type" == "plain" ]]; then + if [[ "$descr" == "_" ]]; then + completions+=("$key") + else + completions_with_descriptions+=("$key":"$descr") + fi + elif [[ "$type" == "dir" ]]; then + _path_files -/ + elif [[ "$type" == "file" ]]; then + _path_files -f + fi + done + + if [ -n "$completions_with_descriptions" ]; then + _describe -V unsorted completions_with_descriptions -U + fi + + if [ -n "$completions" ]; then + compadd -U -V unsorted -a completions + fi +} + +compdef %(complete_func)s %(prog_name)s; +""" + +_SOURCE_FISH = """\ +function %(complete_func)s; + set -l response; + + for value in (env %(complete_var)s=fish_complete COMP_WORDS=(commandline -cp) \ +COMP_CWORD=(commandline -t) %(prog_name)s); + set response $response $value; + end; + + for completion in $response; + set -l metadata (string split "," $completion); + + if test $metadata[1] = "dir"; + __fish_complete_directories $metadata[2]; + else if test $metadata[1] = "file"; + __fish_complete_path $metadata[2]; + else if test $metadata[1] = "plain"; + echo $metadata[2]; + end; + end; +end; + +complete --no-files --command %(prog_name)s --arguments \ +"(%(complete_func)s)"; +""" + + +class ShellComplete: + """Base class for providing shell completion support. A subclass for + a given shell will override attributes and methods to implement the + completion instructions (``source`` and ``complete``). + + :param cli: Command being called. + :param prog_name: Name of the executable in the shell. + :param complete_var: Name of the environment variable that holds + the completion instruction. + + .. versionadded:: 8.0 + """ + + name: t.ClassVar[str] + """Name to register the shell as with :func:`add_completion_class`. + This is used in completion instructions (``{name}_source`` and + ``{name}_complete``). + """ + + source_template: t.ClassVar[str] + """Completion script template formatted by :meth:`source`. This must + be provided by subclasses. + """ + + def __init__( + self, + cli: BaseCommand, + ctx_args: t.Dict[str, t.Any], + prog_name: str, + complete_var: str, + ) -> None: + self.cli = cli + self.ctx_args = ctx_args + self.prog_name = prog_name + self.complete_var = complete_var + + @property + def func_name(self) -> str: + """The name of the shell function defined by the completion + script. + """ + safe_name = re.sub(r"\W*", "", self.prog_name.replace("-", "_"), re.ASCII) + return f"_{safe_name}_completion" + + def source_vars(self) -> t.Dict[str, t.Any]: + """Vars for formatting :attr:`source_template`. + + By default this provides ``complete_func``, ``complete_var``, + and ``prog_name``. + """ + return { + "complete_func": self.func_name, + "complete_var": self.complete_var, + "prog_name": self.prog_name, + } + + def source(self) -> str: + """Produce the shell script that defines the completion + function. By default this ``%``-style formats + :attr:`source_template` with the dict returned by + :meth:`source_vars`. + """ + return self.source_template % self.source_vars() + + def get_completion_args(self) -> t.Tuple[t.List[str], str]: + """Use the env vars defined by the shell script to return a + tuple of ``args, incomplete``. This must be implemented by + subclasses. + """ + raise NotImplementedError + + def get_completions( + self, args: t.List[str], incomplete: str + ) -> t.List[CompletionItem]: + """Determine the context and last complete command or parameter + from the complete args. Call that object's ``shell_complete`` + method to get the completions for the incomplete value. + + :param args: List of complete args before the incomplete value. + :param incomplete: Value being completed. May be empty. + """ + ctx = _resolve_context(self.cli, self.ctx_args, self.prog_name, args) + obj, incomplete = _resolve_incomplete(ctx, args, incomplete) + return obj.shell_complete(ctx, incomplete) + + def format_completion(self, item: CompletionItem) -> str: + """Format a completion item into the form recognized by the + shell script. This must be implemented by subclasses. + + :param item: Completion item to format. + """ + raise NotImplementedError + + def complete(self) -> str: + """Produce the completion data to send back to the shell. + + By default this calls :meth:`get_completion_args`, gets the + completions, then calls :meth:`format_completion` for each + completion. + """ + args, incomplete = self.get_completion_args() + completions = self.get_completions(args, incomplete) + out = [self.format_completion(item) for item in completions] + return "\n".join(out) + + +class BashComplete(ShellComplete): + """Shell completion for Bash.""" + + name = "bash" + source_template = _SOURCE_BASH + + def _check_version(self) -> None: + import subprocess + + output = subprocess.run( + ["bash", "-c", "echo ${BASH_VERSION}"], stdout=subprocess.PIPE + ) + match = re.search(r"^(\d+)\.(\d+)\.\d+", output.stdout.decode()) + + if match is not None: + major, minor = match.groups() + + if major < "4" or major == "4" and minor < "4": + raise RuntimeError( + _( + "Shell completion is not supported for Bash" + " versions older than 4.4." + ) + ) + else: + raise RuntimeError( + _("Couldn't detect Bash version, shell completion is not supported.") + ) + + def source(self) -> str: + self._check_version() + return super().source() + + def get_completion_args(self) -> t.Tuple[t.List[str], str]: + cwords = split_arg_string(os.environ["COMP_WORDS"]) + cword = int(os.environ["COMP_CWORD"]) + args = cwords[1:cword] + + try: + incomplete = cwords[cword] + except IndexError: + incomplete = "" + + return args, incomplete + + def format_completion(self, item: CompletionItem) -> str: + return f"{item.type},{item.value}" + + +class ZshComplete(ShellComplete): + """Shell completion for Zsh.""" + + name = "zsh" + source_template = _SOURCE_ZSH + + def get_completion_args(self) -> t.Tuple[t.List[str], str]: + cwords = split_arg_string(os.environ["COMP_WORDS"]) + cword = int(os.environ["COMP_CWORD"]) + args = cwords[1:cword] + + try: + incomplete = cwords[cword] + except IndexError: + incomplete = "" + + return args, incomplete + + def format_completion(self, item: CompletionItem) -> str: + return f"{item.type}\n{item.value}\n{item.help if item.help else '_'}" + + +class FishComplete(ShellComplete): + """Shell completion for Fish.""" + + name = "fish" + source_template = _SOURCE_FISH + + def get_completion_args(self) -> t.Tuple[t.List[str], str]: + cwords = split_arg_string(os.environ["COMP_WORDS"]) + incomplete = os.environ["COMP_CWORD"] + args = cwords[1:] + + # Fish stores the partial word in both COMP_WORDS and + # COMP_CWORD, remove it from complete args. + if incomplete and args and args[-1] == incomplete: + args.pop() + + return args, incomplete + + def format_completion(self, item: CompletionItem) -> str: + if item.help: + return f"{item.type},{item.value}\t{item.help}" + + return f"{item.type},{item.value}" + + +_available_shells: t.Dict[str, t.Type[ShellComplete]] = { + "bash": BashComplete, + "fish": FishComplete, + "zsh": ZshComplete, +} + + +def add_completion_class( + cls: t.Type[ShellComplete], name: t.Optional[str] = None +) -> None: + """Register a :class:`ShellComplete` subclass under the given name. + The name will be provided by the completion instruction environment + variable during completion. + + :param cls: The completion class that will handle completion for the + shell. + :param name: Name to register the class under. Defaults to the + class's ``name`` attribute. + """ + if name is None: + name = cls.name + + _available_shells[name] = cls + + +def get_completion_class(shell: str) -> t.Optional[t.Type[ShellComplete]]: + """Look up a registered :class:`ShellComplete` subclass by the name + provided by the completion instruction environment variable. If the + name isn't registered, returns ``None``. + + :param shell: Name the class is registered under. + """ + return _available_shells.get(shell) + + +def _is_incomplete_argument(ctx: Context, param: Parameter) -> bool: + """Determine if the given parameter is an argument that can still + accept values. + + :param ctx: Invocation context for the command represented by the + parsed complete args. + :param param: Argument object being checked. + """ + if not isinstance(param, Argument): + return False + + assert param.name is not None + value = ctx.params[param.name] + return ( + param.nargs == -1 + or ctx.get_parameter_source(param.name) is not ParameterSource.COMMANDLINE + or ( + param.nargs > 1 + and isinstance(value, (tuple, list)) + and len(value) < param.nargs + ) + ) + + +def _start_of_option(value: str) -> bool: + """Check if the value looks like the start of an option.""" + if not value: + return False + + c = value[0] + # Allow "/" since that starts a path. + return not c.isalnum() and c != "/" + + +def _is_incomplete_option(args: t.List[str], param: Parameter) -> bool: + """Determine if the given parameter is an option that needs a value. + + :param args: List of complete args before the incomplete value. + :param param: Option object being checked. + """ + if not isinstance(param, Option): + return False + + if param.is_flag: + return False + + last_option = None + + for index, arg in enumerate(reversed(args)): + if index + 1 > param.nargs: + break + + if _start_of_option(arg): + last_option = arg + + return last_option is not None and last_option in param.opts + + +def _resolve_context( + cli: BaseCommand, ctx_args: t.Dict[str, t.Any], prog_name: str, args: t.List[str] +) -> Context: + """Produce the context hierarchy starting with the command and + traversing the complete arguments. This only follows the commands, + it doesn't trigger input prompts or callbacks. + + :param cli: Command being called. + :param prog_name: Name of the executable in the shell. + :param args: List of complete args before the incomplete value. + """ + ctx_args["resilient_parsing"] = True + ctx = cli.make_context(prog_name, args.copy(), **ctx_args) + args = ctx.protected_args + ctx.args + + while args: + command = ctx.command + + if isinstance(command, MultiCommand): + if not command.chain: + name, cmd, args = command.resolve_command(ctx, args) + + if cmd is None: + return ctx + + ctx = cmd.make_context(name, args, parent=ctx, resilient_parsing=True) + args = ctx.protected_args + ctx.args + else: + while args: + name, cmd, args = command.resolve_command(ctx, args) + + if cmd is None: + return ctx + + sub_ctx = cmd.make_context( + name, + args, + parent=ctx, + allow_extra_args=True, + allow_interspersed_args=False, + resilient_parsing=True, + ) + args = sub_ctx.args + + ctx = sub_ctx + args = [*sub_ctx.protected_args, *sub_ctx.args] + else: + break + + return ctx + + +def _resolve_incomplete( + ctx: Context, args: t.List[str], incomplete: str +) -> t.Tuple[t.Union[BaseCommand, Parameter], str]: + """Find the Click object that will handle the completion of the + incomplete value. Return the object and the incomplete value. + + :param ctx: Invocation context for the command represented by + the parsed complete args. + :param args: List of complete args before the incomplete value. + :param incomplete: Value being completed. May be empty. + """ + # Different shells treat an "=" between a long option name and + # value differently. Might keep the value joined, return the "=" + # as a separate item, or return the split name and value. Always + # split and discard the "=" to make completion easier. + if incomplete == "=": + incomplete = "" + elif "=" in incomplete and _start_of_option(incomplete): + name, _, incomplete = incomplete.partition("=") + args.append(name) + + # The "--" marker tells Click to stop treating values as options + # even if they start with the option character. If it hasn't been + # given and the incomplete arg looks like an option, the current + # command will provide option name completions. + if "--" not in args and _start_of_option(incomplete): + return ctx.command, incomplete + + params = ctx.command.get_params(ctx) + + # If the last complete arg is an option name with an incomplete + # value, the option will provide value completions. + for param in params: + if _is_incomplete_option(args, param): + return param, incomplete + + # It's not an option name or value. The first argument without a + # parsed value will provide value completions. + for param in params: + if _is_incomplete_argument(ctx, param): + return param, incomplete + + # There were no unparsed arguments, the command may be a group that + # will provide command name completions. + return ctx.command, incomplete diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/termui.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/termui.py new file mode 100644 index 00000000..cf8d5f13 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/termui.py @@ -0,0 +1,809 @@ +import inspect +import io +import itertools +import os +import sys +import typing +import typing as t +from gettext import gettext as _ + +from ._compat import isatty +from ._compat import strip_ansi +from ._compat import WIN +from .exceptions import Abort +from .exceptions import UsageError +from .globals import resolve_color_default +from .types import Choice +from .types import convert_type +from .types import ParamType +from .utils import echo +from .utils import LazyFile + +if t.TYPE_CHECKING: + from ._termui_impl import ProgressBar + +V = t.TypeVar("V") + +# The prompt functions to use. The doc tools currently override these +# functions to customize how they work. +visible_prompt_func: t.Callable[[str], str] = input + +_ansi_colors = { + "black": 30, + "red": 31, + "green": 32, + "yellow": 33, + "blue": 34, + "magenta": 35, + "cyan": 36, + "white": 37, + "reset": 39, + "bright_black": 90, + "bright_red": 91, + "bright_green": 92, + "bright_yellow": 93, + "bright_blue": 94, + "bright_magenta": 95, + "bright_cyan": 96, + "bright_white": 97, +} +_ansi_reset_all = "\033[0m" + + +def hidden_prompt_func(prompt: str) -> str: + import getpass + + return getpass.getpass(prompt) + + +def _build_prompt( + text: str, + suffix: str, + show_default: bool = False, + default: t.Optional[t.Any] = None, + show_choices: bool = True, + type: t.Optional[ParamType] = None, +) -> str: + prompt = text + if type is not None and show_choices and isinstance(type, Choice): + prompt += f" ({', '.join(map(str, type.choices))})" + if default is not None and show_default: + prompt = f"{prompt} [{_format_default(default)}]" + return f"{prompt}{suffix}" + + +def _format_default(default: t.Any) -> t.Any: + if isinstance(default, (io.IOBase, LazyFile)) and hasattr(default, "name"): + return default.name # type: ignore + + return default + + +def prompt( + text: str, + default: t.Optional[t.Any] = None, + hide_input: bool = False, + confirmation_prompt: t.Union[bool, str] = False, + type: t.Optional[t.Union[ParamType, t.Any]] = None, + value_proc: t.Optional[t.Callable[[str], t.Any]] = None, + prompt_suffix: str = ": ", + show_default: bool = True, + err: bool = False, + show_choices: bool = True, +) -> t.Any: + """Prompts a user for input. This is a convenience function that can + be used to prompt a user for input later. + + If the user aborts the input by sending a interrupt signal, this + function will catch it and raise a :exc:`Abort` exception. + + :param text: the text to show for the prompt. + :param default: the default value to use if no input happens. If this + is not given it will prompt until it's aborted. + :param hide_input: if this is set to true then the input value will + be hidden. + :param confirmation_prompt: Prompt a second time to confirm the + value. Can be set to a string instead of ``True`` to customize + the message. + :param type: the type to use to check the value against. + :param value_proc: if this parameter is provided it's a function that + is invoked instead of the type conversion to + convert a value. + :param prompt_suffix: a suffix that should be added to the prompt. + :param show_default: shows or hides the default value in the prompt. + :param err: if set to true the file defaults to ``stderr`` instead of + ``stdout``, the same as with echo. + :param show_choices: Show or hide choices if the passed type is a Choice. + For example if type is a Choice of either day or week, + show_choices is true and text is "Group by" then the + prompt will be "Group by (day, week): ". + + .. versionadded:: 8.0 + ``confirmation_prompt`` can be a custom string. + + .. versionadded:: 7.0 + Added the ``show_choices`` parameter. + + .. versionadded:: 6.0 + Added unicode support for cmd.exe on Windows. + + .. versionadded:: 4.0 + Added the `err` parameter. + + """ + + def prompt_func(text: str) -> str: + f = hidden_prompt_func if hide_input else visible_prompt_func + try: + # Write the prompt separately so that we get nice + # coloring through colorama on Windows + echo(text.rstrip(" "), nl=False, err=err) + # Echo a space to stdout to work around an issue where + # readline causes backspace to clear the whole line. + return f(" ") + except (KeyboardInterrupt, EOFError): + # getpass doesn't print a newline if the user aborts input with ^C. + # Allegedly this behavior is inherited from getpass(3). + # A doc bug has been filed at https://bugs.python.org/issue24711 + if hide_input: + echo(None, err=err) + raise Abort() from None + + if value_proc is None: + value_proc = convert_type(type, default) + + prompt = _build_prompt( + text, prompt_suffix, show_default, default, show_choices, type + ) + + if confirmation_prompt: + if confirmation_prompt is True: + confirmation_prompt = _("Repeat for confirmation") + + confirmation_prompt = t.cast(str, confirmation_prompt) + confirmation_prompt = _build_prompt(confirmation_prompt, prompt_suffix) + + while True: + while True: + value = prompt_func(prompt) + if value: + break + elif default is not None: + value = default + break + try: + result = value_proc(value) + except UsageError as e: + if hide_input: + echo(_("Error: The value you entered was invalid."), err=err) + else: + echo(_("Error: {e.message}").format(e=e), err=err) # noqa: B306 + continue + if not confirmation_prompt: + return result + while True: + confirmation_prompt = t.cast(str, confirmation_prompt) + value2 = prompt_func(confirmation_prompt) + if value2: + break + if value == value2: + return result + echo(_("Error: The two entered values do not match."), err=err) + + +def confirm( + text: str, + default: t.Optional[bool] = False, + abort: bool = False, + prompt_suffix: str = ": ", + show_default: bool = True, + err: bool = False, +) -> bool: + """Prompts for confirmation (yes/no question). + + If the user aborts the input by sending a interrupt signal this + function will catch it and raise a :exc:`Abort` exception. + + :param text: the question to ask. + :param default: The default value to use when no input is given. If + ``None``, repeat until input is given. + :param abort: if this is set to `True` a negative answer aborts the + exception by raising :exc:`Abort`. + :param prompt_suffix: a suffix that should be added to the prompt. + :param show_default: shows or hides the default value in the prompt. + :param err: if set to true the file defaults to ``stderr`` instead of + ``stdout``, the same as with echo. + + .. versionchanged:: 8.0 + Repeat until input is given if ``default`` is ``None``. + + .. versionadded:: 4.0 + Added the ``err`` parameter. + """ + prompt = _build_prompt( + text, + prompt_suffix, + show_default, + "y/n" if default is None else ("Y/n" if default else "y/N"), + ) + + while True: + try: + # Write the prompt separately so that we get nice + # coloring through colorama on Windows + echo(prompt.rstrip(" "), nl=False, err=err) + # Echo a space to stdout to work around an issue where + # readline causes backspace to clear the whole line. + value = visible_prompt_func(" ").lower().strip() + except (KeyboardInterrupt, EOFError): + raise Abort() from None + if value in ("y", "yes"): + rv = True + elif value in ("n", "no"): + rv = False + elif default is not None and value == "": + rv = default + else: + echo(_("Error: invalid input"), err=err) + continue + break + if abort and not rv: + raise Abort() + return rv + + +def get_terminal_size() -> os.terminal_size: + """Returns the current size of the terminal as tuple in the form + ``(width, height)`` in columns and rows. + + .. deprecated:: 8.0 + Will be removed in Click 8.1. Use + :func:`shutil.get_terminal_size` instead. + """ + import shutil + import warnings + + warnings.warn( + "'click.get_terminal_size()' is deprecated and will be removed" + " in Click 8.1. Use 'shutil.get_terminal_size()' instead.", + DeprecationWarning, + stacklevel=2, + ) + return shutil.get_terminal_size() + + +def echo_via_pager( + text_or_generator: t.Union[t.Iterable[str], t.Callable[[], t.Iterable[str]], str], + color: t.Optional[bool] = None, +) -> None: + """This function takes a text and shows it via an environment specific + pager on stdout. + + .. versionchanged:: 3.0 + Added the `color` flag. + + :param text_or_generator: the text to page, or alternatively, a + generator emitting the text to page. + :param color: controls if the pager supports ANSI colors or not. The + default is autodetection. + """ + color = resolve_color_default(color) + + if inspect.isgeneratorfunction(text_or_generator): + i = t.cast(t.Callable[[], t.Iterable[str]], text_or_generator)() + elif isinstance(text_or_generator, str): + i = [text_or_generator] + else: + i = iter(t.cast(t.Iterable[str], text_or_generator)) + + # convert every element of i to a text type if necessary + text_generator = (el if isinstance(el, str) else str(el) for el in i) + + from ._termui_impl import pager + + return pager(itertools.chain(text_generator, "\n"), color) + + +def progressbar( + iterable: t.Optional[t.Iterable[V]] = None, + length: t.Optional[int] = None, + label: t.Optional[str] = None, + show_eta: bool = True, + show_percent: t.Optional[bool] = None, + show_pos: bool = False, + item_show_func: t.Optional[t.Callable[[t.Optional[V]], t.Optional[str]]] = None, + fill_char: str = "#", + empty_char: str = "-", + bar_template: str = "%(label)s [%(bar)s] %(info)s", + info_sep: str = " ", + width: int = 36, + file: t.Optional[t.TextIO] = None, + color: t.Optional[bool] = None, + update_min_steps: int = 1, +) -> "ProgressBar[V]": + """This function creates an iterable context manager that can be used + to iterate over something while showing a progress bar. It will + either iterate over the `iterable` or `length` items (that are counted + up). While iteration happens, this function will print a rendered + progress bar to the given `file` (defaults to stdout) and will attempt + to calculate remaining time and more. By default, this progress bar + will not be rendered if the file is not a terminal. + + The context manager creates the progress bar. When the context + manager is entered the progress bar is already created. With every + iteration over the progress bar, the iterable passed to the bar is + advanced and the bar is updated. When the context manager exits, + a newline is printed and the progress bar is finalized on screen. + + Note: The progress bar is currently designed for use cases where the + total progress can be expected to take at least several seconds. + Because of this, the ProgressBar class object won't display + progress that is considered too fast, and progress where the time + between steps is less than a second. + + No printing must happen or the progress bar will be unintentionally + destroyed. + + Example usage:: + + with progressbar(items) as bar: + for item in bar: + do_something_with(item) + + Alternatively, if no iterable is specified, one can manually update the + progress bar through the `update()` method instead of directly + iterating over the progress bar. The update method accepts the number + of steps to increment the bar with:: + + with progressbar(length=chunks.total_bytes) as bar: + for chunk in chunks: + process_chunk(chunk) + bar.update(chunks.bytes) + + The ``update()`` method also takes an optional value specifying the + ``current_item`` at the new position. This is useful when used + together with ``item_show_func`` to customize the output for each + manual step:: + + with click.progressbar( + length=total_size, + label='Unzipping archive', + item_show_func=lambda a: a.filename + ) as bar: + for archive in zip_file: + archive.extract() + bar.update(archive.size, archive) + + :param iterable: an iterable to iterate over. If not provided the length + is required. + :param length: the number of items to iterate over. By default the + progressbar will attempt to ask the iterator about its + length, which might or might not work. If an iterable is + also provided this parameter can be used to override the + length. If an iterable is not provided the progress bar + will iterate over a range of that length. + :param label: the label to show next to the progress bar. + :param show_eta: enables or disables the estimated time display. This is + automatically disabled if the length cannot be + determined. + :param show_percent: enables or disables the percentage display. The + default is `True` if the iterable has a length or + `False` if not. + :param show_pos: enables or disables the absolute position display. The + default is `False`. + :param item_show_func: A function called with the current item which + can return a string to show next to the progress bar. If the + function returns ``None`` nothing is shown. The current item can + be ``None``, such as when entering and exiting the bar. + :param fill_char: the character to use to show the filled part of the + progress bar. + :param empty_char: the character to use to show the non-filled part of + the progress bar. + :param bar_template: the format string to use as template for the bar. + The parameters in it are ``label`` for the label, + ``bar`` for the progress bar and ``info`` for the + info section. + :param info_sep: the separator between multiple info items (eta etc.) + :param width: the width of the progress bar in characters, 0 means full + terminal width + :param file: The file to write to. If this is not a terminal then + only the label is printed. + :param color: controls if the terminal supports ANSI colors or not. The + default is autodetection. This is only needed if ANSI + codes are included anywhere in the progress bar output + which is not the case by default. + :param update_min_steps: Render only when this many updates have + completed. This allows tuning for very fast iterators. + + .. versionchanged:: 8.0 + Output is shown even if execution time is less than 0.5 seconds. + + .. versionchanged:: 8.0 + ``item_show_func`` shows the current item, not the previous one. + + .. versionchanged:: 8.0 + Labels are echoed if the output is not a TTY. Reverts a change + in 7.0 that removed all output. + + .. versionadded:: 8.0 + Added the ``update_min_steps`` parameter. + + .. versionchanged:: 4.0 + Added the ``color`` parameter. Added the ``update`` method to + the object. + + .. versionadded:: 2.0 + """ + from ._termui_impl import ProgressBar + + color = resolve_color_default(color) + return ProgressBar( + iterable=iterable, + length=length, + show_eta=show_eta, + show_percent=show_percent, + show_pos=show_pos, + item_show_func=item_show_func, + fill_char=fill_char, + empty_char=empty_char, + bar_template=bar_template, + info_sep=info_sep, + file=file, + label=label, + width=width, + color=color, + update_min_steps=update_min_steps, + ) + + +def clear() -> None: + """Clears the terminal screen. This will have the effect of clearing + the whole visible space of the terminal and moving the cursor to the + top left. This does not do anything if not connected to a terminal. + + .. versionadded:: 2.0 + """ + if not isatty(sys.stdout): + return + if WIN: + os.system("cls") + else: + sys.stdout.write("\033[2J\033[1;1H") + + +def _interpret_color( + color: t.Union[int, t.Tuple[int, int, int], str], offset: int = 0 +) -> str: + if isinstance(color, int): + return f"{38 + offset};5;{color:d}" + + if isinstance(color, (tuple, list)): + r, g, b = color + return f"{38 + offset};2;{r:d};{g:d};{b:d}" + + return str(_ansi_colors[color] + offset) + + +def style( + text: t.Any, + fg: t.Optional[t.Union[int, t.Tuple[int, int, int], str]] = None, + bg: t.Optional[t.Union[int, t.Tuple[int, int, int], str]] = None, + bold: t.Optional[bool] = None, + dim: t.Optional[bool] = None, + underline: t.Optional[bool] = None, + overline: t.Optional[bool] = None, + italic: t.Optional[bool] = None, + blink: t.Optional[bool] = None, + reverse: t.Optional[bool] = None, + strikethrough: t.Optional[bool] = None, + reset: bool = True, +) -> str: + """Styles a text with ANSI styles and returns the new string. By + default the styling is self contained which means that at the end + of the string a reset code is issued. This can be prevented by + passing ``reset=False``. + + Examples:: + + click.echo(click.style('Hello World!', fg='green')) + click.echo(click.style('ATTENTION!', blink=True)) + click.echo(click.style('Some things', reverse=True, fg='cyan')) + click.echo(click.style('More colors', fg=(255, 12, 128), bg=117)) + + Supported color names: + + * ``black`` (might be a gray) + * ``red`` + * ``green`` + * ``yellow`` (might be an orange) + * ``blue`` + * ``magenta`` + * ``cyan`` + * ``white`` (might be light gray) + * ``bright_black`` + * ``bright_red`` + * ``bright_green`` + * ``bright_yellow`` + * ``bright_blue`` + * ``bright_magenta`` + * ``bright_cyan`` + * ``bright_white`` + * ``reset`` (reset the color code only) + + If the terminal supports it, color may also be specified as: + + - An integer in the interval [0, 255]. The terminal must support + 8-bit/256-color mode. + - An RGB tuple of three integers in [0, 255]. The terminal must + support 24-bit/true-color mode. + + See https://en.wikipedia.org/wiki/ANSI_color and + https://gist.github.com/XVilka/8346728 for more information. + + :param text: the string to style with ansi codes. + :param fg: if provided this will become the foreground color. + :param bg: if provided this will become the background color. + :param bold: if provided this will enable or disable bold mode. + :param dim: if provided this will enable or disable dim mode. This is + badly supported. + :param underline: if provided this will enable or disable underline. + :param overline: if provided this will enable or disable overline. + :param italic: if provided this will enable or disable italic. + :param blink: if provided this will enable or disable blinking. + :param reverse: if provided this will enable or disable inverse + rendering (foreground becomes background and the + other way round). + :param strikethrough: if provided this will enable or disable + striking through text. + :param reset: by default a reset-all code is added at the end of the + string which means that styles do not carry over. This + can be disabled to compose styles. + + .. versionchanged:: 8.0 + A non-string ``message`` is converted to a string. + + .. versionchanged:: 8.0 + Added support for 256 and RGB color codes. + + .. versionchanged:: 8.0 + Added the ``strikethrough``, ``italic``, and ``overline`` + parameters. + + .. versionchanged:: 7.0 + Added support for bright colors. + + .. versionadded:: 2.0 + """ + if not isinstance(text, str): + text = str(text) + + bits = [] + + if fg: + try: + bits.append(f"\033[{_interpret_color(fg)}m") + except KeyError: + raise TypeError(f"Unknown color {fg!r}") from None + + if bg: + try: + bits.append(f"\033[{_interpret_color(bg, 10)}m") + except KeyError: + raise TypeError(f"Unknown color {bg!r}") from None + + if bold is not None: + bits.append(f"\033[{1 if bold else 22}m") + if dim is not None: + bits.append(f"\033[{2 if dim else 22}m") + if underline is not None: + bits.append(f"\033[{4 if underline else 24}m") + if overline is not None: + bits.append(f"\033[{53 if overline else 55}m") + if italic is not None: + bits.append(f"\033[{3 if italic else 23}m") + if blink is not None: + bits.append(f"\033[{5 if blink else 25}m") + if reverse is not None: + bits.append(f"\033[{7 if reverse else 27}m") + if strikethrough is not None: + bits.append(f"\033[{9 if strikethrough else 29}m") + bits.append(text) + if reset: + bits.append(_ansi_reset_all) + return "".join(bits) + + +def unstyle(text: str) -> str: + """Removes ANSI styling information from a string. Usually it's not + necessary to use this function as Click's echo function will + automatically remove styling if necessary. + + .. versionadded:: 2.0 + + :param text: the text to remove style information from. + """ + return strip_ansi(text) + + +def secho( + message: t.Optional[t.Any] = None, + file: t.Optional[t.IO] = None, + nl: bool = True, + err: bool = False, + color: t.Optional[bool] = None, + **styles: t.Any, +) -> None: + """This function combines :func:`echo` and :func:`style` into one + call. As such the following two calls are the same:: + + click.secho('Hello World!', fg='green') + click.echo(click.style('Hello World!', fg='green')) + + All keyword arguments are forwarded to the underlying functions + depending on which one they go with. + + Non-string types will be converted to :class:`str`. However, + :class:`bytes` are passed directly to :meth:`echo` without applying + style. If you want to style bytes that represent text, call + :meth:`bytes.decode` first. + + .. versionchanged:: 8.0 + A non-string ``message`` is converted to a string. Bytes are + passed through without style applied. + + .. versionadded:: 2.0 + """ + if message is not None and not isinstance(message, (bytes, bytearray)): + message = style(message, **styles) + + return echo(message, file=file, nl=nl, err=err, color=color) + + +def edit( + text: t.Optional[t.AnyStr] = None, + editor: t.Optional[str] = None, + env: t.Optional[t.Mapping[str, str]] = None, + require_save: bool = True, + extension: str = ".txt", + filename: t.Optional[str] = None, +) -> t.Optional[t.AnyStr]: + r"""Edits the given text in the defined editor. If an editor is given + (should be the full path to the executable but the regular operating + system search path is used for finding the executable) it overrides + the detected editor. Optionally, some environment variables can be + used. If the editor is closed without changes, `None` is returned. In + case a file is edited directly the return value is always `None` and + `require_save` and `extension` are ignored. + + If the editor cannot be opened a :exc:`UsageError` is raised. + + Note for Windows: to simplify cross-platform usage, the newlines are + automatically converted from POSIX to Windows and vice versa. As such, + the message here will have ``\n`` as newline markers. + + :param text: the text to edit. + :param editor: optionally the editor to use. Defaults to automatic + detection. + :param env: environment variables to forward to the editor. + :param require_save: if this is true, then not saving in the editor + will make the return value become `None`. + :param extension: the extension to tell the editor about. This defaults + to `.txt` but changing this might change syntax + highlighting. + :param filename: if provided it will edit this file instead of the + provided text contents. It will not use a temporary + file as an indirection in that case. + """ + from ._termui_impl import Editor + + ed = Editor(editor=editor, env=env, require_save=require_save, extension=extension) + + if filename is None: + return ed.edit(text) + + ed.edit_file(filename) + return None + + +def launch(url: str, wait: bool = False, locate: bool = False) -> int: + """This function launches the given URL (or filename) in the default + viewer application for this file type. If this is an executable, it + might launch the executable in a new session. The return value is + the exit code of the launched application. Usually, ``0`` indicates + success. + + Examples:: + + click.launch('https://click.palletsprojects.com/') + click.launch('/my/downloaded/file', locate=True) + + .. versionadded:: 2.0 + + :param url: URL or filename of the thing to launch. + :param wait: Wait for the program to exit before returning. This + only works if the launched program blocks. In particular, + ``xdg-open`` on Linux does not block. + :param locate: if this is set to `True` then instead of launching the + application associated with the URL it will attempt to + launch a file manager with the file located. This + might have weird effects if the URL does not point to + the filesystem. + """ + from ._termui_impl import open_url + + return open_url(url, wait=wait, locate=locate) + + +# If this is provided, getchar() calls into this instead. This is used +# for unittesting purposes. +_getchar: t.Optional[t.Callable[[bool], str]] = None + + +def getchar(echo: bool = False) -> str: + """Fetches a single character from the terminal and returns it. This + will always return a unicode character and under certain rare + circumstances this might return more than one character. The + situations which more than one character is returned is when for + whatever reason multiple characters end up in the terminal buffer or + standard input was not actually a terminal. + + Note that this will always read from the terminal, even if something + is piped into the standard input. + + Note for Windows: in rare cases when typing non-ASCII characters, this + function might wait for a second character and then return both at once. + This is because certain Unicode characters look like special-key markers. + + .. versionadded:: 2.0 + + :param echo: if set to `True`, the character read will also show up on + the terminal. The default is to not show it. + """ + global _getchar + + if _getchar is None: + from ._termui_impl import getchar as f + + _getchar = f + + return _getchar(echo) + + +def raw_terminal() -> t.ContextManager[int]: + from ._termui_impl import raw_terminal as f + + return f() + + +def pause(info: t.Optional[str] = None, err: bool = False) -> None: + """This command stops execution and waits for the user to press any + key to continue. This is similar to the Windows batch "pause" + command. If the program is not run through a terminal, this command + will instead do nothing. + + .. versionadded:: 2.0 + + .. versionadded:: 4.0 + Added the `err` parameter. + + :param info: The message to print before pausing. Defaults to + ``"Press any key to continue..."``. + :param err: if set to message goes to ``stderr`` instead of + ``stdout``, the same as with echo. + """ + if not isatty(sys.stdin) or not isatty(sys.stdout): + return + + if info is None: + info = _("Press any key to continue...") + + try: + if info: + echo(info, nl=False, err=err) + try: + getchar() + except (KeyboardInterrupt, EOFError): + pass + finally: + if info: + echo(err=err) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/testing.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/testing.py new file mode 100644 index 00000000..d19b850f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/testing.py @@ -0,0 +1,479 @@ +import contextlib +import io +import os +import shlex +import shutil +import sys +import tempfile +import typing as t +from types import TracebackType + +from . import formatting +from . import termui +from . import utils +from ._compat import _find_binary_reader + +if t.TYPE_CHECKING: + from .core import BaseCommand + + +class EchoingStdin: + def __init__(self, input: t.BinaryIO, output: t.BinaryIO) -> None: + self._input = input + self._output = output + self._paused = False + + def __getattr__(self, x: str) -> t.Any: + return getattr(self._input, x) + + def _echo(self, rv: bytes) -> bytes: + if not self._paused: + self._output.write(rv) + + return rv + + def read(self, n: int = -1) -> bytes: + return self._echo(self._input.read(n)) + + def read1(self, n: int = -1) -> bytes: + return self._echo(self._input.read1(n)) # type: ignore + + def readline(self, n: int = -1) -> bytes: + return self._echo(self._input.readline(n)) + + def readlines(self) -> t.List[bytes]: + return [self._echo(x) for x in self._input.readlines()] + + def __iter__(self) -> t.Iterator[bytes]: + return iter(self._echo(x) for x in self._input) + + def __repr__(self) -> str: + return repr(self._input) + + +@contextlib.contextmanager +def _pause_echo(stream: t.Optional[EchoingStdin]) -> t.Iterator[None]: + if stream is None: + yield + else: + stream._paused = True + yield + stream._paused = False + + +class _NamedTextIOWrapper(io.TextIOWrapper): + def __init__( + self, buffer: t.BinaryIO, name: str, mode: str, **kwargs: t.Any + ) -> None: + super().__init__(buffer, **kwargs) + self._name = name + self._mode = mode + + @property + def name(self) -> str: + return self._name + + @property + def mode(self) -> str: + return self._mode + + +def make_input_stream( + input: t.Optional[t.Union[str, bytes, t.IO]], charset: str +) -> t.BinaryIO: + # Is already an input stream. + if hasattr(input, "read"): + rv = _find_binary_reader(t.cast(t.IO, input)) + + if rv is not None: + return rv + + raise TypeError("Could not find binary reader for input stream.") + + if input is None: + input = b"" + elif isinstance(input, str): + input = input.encode(charset) + + return io.BytesIO(t.cast(bytes, input)) + + +class Result: + """Holds the captured result of an invoked CLI script.""" + + def __init__( + self, + runner: "CliRunner", + stdout_bytes: bytes, + stderr_bytes: t.Optional[bytes], + return_value: t.Any, + exit_code: int, + exception: t.Optional[BaseException], + exc_info: t.Optional[ + t.Tuple[t.Type[BaseException], BaseException, TracebackType] + ] = None, + ): + #: The runner that created the result + self.runner = runner + #: The standard output as bytes. + self.stdout_bytes = stdout_bytes + #: The standard error as bytes, or None if not available + self.stderr_bytes = stderr_bytes + #: The value returned from the invoked command. + #: + #: .. versionadded:: 8.0 + self.return_value = return_value + #: The exit code as integer. + self.exit_code = exit_code + #: The exception that happened if one did. + self.exception = exception + #: The traceback + self.exc_info = exc_info + + @property + def output(self) -> str: + """The (standard) output as unicode string.""" + return self.stdout + + @property + def stdout(self) -> str: + """The standard output as unicode string.""" + return self.stdout_bytes.decode(self.runner.charset, "replace").replace( + "\r\n", "\n" + ) + + @property + def stderr(self) -> str: + """The standard error as unicode string.""" + if self.stderr_bytes is None: + raise ValueError("stderr not separately captured") + return self.stderr_bytes.decode(self.runner.charset, "replace").replace( + "\r\n", "\n" + ) + + def __repr__(self) -> str: + exc_str = repr(self.exception) if self.exception else "okay" + return f"<{type(self).__name__} {exc_str}>" + + +class CliRunner: + """The CLI runner provides functionality to invoke a Click command line + script for unittesting purposes in a isolated environment. This only + works in single-threaded systems without any concurrency as it changes the + global interpreter state. + + :param charset: the character set for the input and output data. + :param env: a dictionary with environment variables for overriding. + :param echo_stdin: if this is set to `True`, then reading from stdin writes + to stdout. This is useful for showing examples in + some circumstances. Note that regular prompts + will automatically echo the input. + :param mix_stderr: if this is set to `False`, then stdout and stderr are + preserved as independent streams. This is useful for + Unix-philosophy apps that have predictable stdout and + noisy stderr, such that each may be measured + independently + """ + + def __init__( + self, + charset: str = "utf-8", + env: t.Optional[t.Mapping[str, t.Optional[str]]] = None, + echo_stdin: bool = False, + mix_stderr: bool = True, + ) -> None: + self.charset = charset + self.env = env or {} + self.echo_stdin = echo_stdin + self.mix_stderr = mix_stderr + + def get_default_prog_name(self, cli: "BaseCommand") -> str: + """Given a command object it will return the default program name + for it. The default is the `name` attribute or ``"root"`` if not + set. + """ + return cli.name or "root" + + def make_env( + self, overrides: t.Optional[t.Mapping[str, t.Optional[str]]] = None + ) -> t.Mapping[str, t.Optional[str]]: + """Returns the environment overrides for invoking a script.""" + rv = dict(self.env) + if overrides: + rv.update(overrides) + return rv + + @contextlib.contextmanager + def isolation( + self, + input: t.Optional[t.Union[str, bytes, t.IO]] = None, + env: t.Optional[t.Mapping[str, t.Optional[str]]] = None, + color: bool = False, + ) -> t.Iterator[t.Tuple[io.BytesIO, t.Optional[io.BytesIO]]]: + """A context manager that sets up the isolation for invoking of a + command line tool. This sets up stdin with the given input data + and `os.environ` with the overrides from the given dictionary. + This also rebinds some internals in Click to be mocked (like the + prompt functionality). + + This is automatically done in the :meth:`invoke` method. + + :param input: the input stream to put into sys.stdin. + :param env: the environment overrides as dictionary. + :param color: whether the output should contain color codes. The + application can still override this explicitly. + + .. versionchanged:: 8.0 + ``stderr`` is opened with ``errors="backslashreplace"`` + instead of the default ``"strict"``. + + .. versionchanged:: 4.0 + Added the ``color`` parameter. + """ + bytes_input = make_input_stream(input, self.charset) + echo_input = None + + old_stdin = sys.stdin + old_stdout = sys.stdout + old_stderr = sys.stderr + old_forced_width = formatting.FORCED_WIDTH + formatting.FORCED_WIDTH = 80 + + env = self.make_env(env) + + bytes_output = io.BytesIO() + + if self.echo_stdin: + bytes_input = echo_input = t.cast( + t.BinaryIO, EchoingStdin(bytes_input, bytes_output) + ) + + sys.stdin = text_input = _NamedTextIOWrapper( + bytes_input, encoding=self.charset, name="", mode="r" + ) + + if self.echo_stdin: + # Force unbuffered reads, otherwise TextIOWrapper reads a + # large chunk which is echoed early. + text_input._CHUNK_SIZE = 1 # type: ignore + + sys.stdout = _NamedTextIOWrapper( + bytes_output, encoding=self.charset, name="", mode="w" + ) + + bytes_error = None + if self.mix_stderr: + sys.stderr = sys.stdout + else: + bytes_error = io.BytesIO() + sys.stderr = _NamedTextIOWrapper( + bytes_error, + encoding=self.charset, + name="", + mode="w", + errors="backslashreplace", + ) + + @_pause_echo(echo_input) # type: ignore + def visible_input(prompt: t.Optional[str] = None) -> str: + sys.stdout.write(prompt or "") + val = text_input.readline().rstrip("\r\n") + sys.stdout.write(f"{val}\n") + sys.stdout.flush() + return val + + @_pause_echo(echo_input) # type: ignore + def hidden_input(prompt: t.Optional[str] = None) -> str: + sys.stdout.write(f"{prompt or ''}\n") + sys.stdout.flush() + return text_input.readline().rstrip("\r\n") + + @_pause_echo(echo_input) # type: ignore + def _getchar(echo: bool) -> str: + char = sys.stdin.read(1) + + if echo: + sys.stdout.write(char) + + sys.stdout.flush() + return char + + default_color = color + + def should_strip_ansi( + stream: t.Optional[t.IO] = None, color: t.Optional[bool] = None + ) -> bool: + if color is None: + return not default_color + return not color + + old_visible_prompt_func = termui.visible_prompt_func + old_hidden_prompt_func = termui.hidden_prompt_func + old__getchar_func = termui._getchar + old_should_strip_ansi = utils.should_strip_ansi # type: ignore + termui.visible_prompt_func = visible_input + termui.hidden_prompt_func = hidden_input + termui._getchar = _getchar + utils.should_strip_ansi = should_strip_ansi # type: ignore + + old_env = {} + try: + for key, value in env.items(): + old_env[key] = os.environ.get(key) + if value is None: + try: + del os.environ[key] + except Exception: + pass + else: + os.environ[key] = value + yield (bytes_output, bytes_error) + finally: + for key, value in old_env.items(): + if value is None: + try: + del os.environ[key] + except Exception: + pass + else: + os.environ[key] = value + sys.stdout = old_stdout + sys.stderr = old_stderr + sys.stdin = old_stdin + termui.visible_prompt_func = old_visible_prompt_func + termui.hidden_prompt_func = old_hidden_prompt_func + termui._getchar = old__getchar_func + utils.should_strip_ansi = old_should_strip_ansi # type: ignore + formatting.FORCED_WIDTH = old_forced_width + + def invoke( + self, + cli: "BaseCommand", + args: t.Optional[t.Union[str, t.Sequence[str]]] = None, + input: t.Optional[t.Union[str, bytes, t.IO]] = None, + env: t.Optional[t.Mapping[str, t.Optional[str]]] = None, + catch_exceptions: bool = True, + color: bool = False, + **extra: t.Any, + ) -> Result: + """Invokes a command in an isolated environment. The arguments are + forwarded directly to the command line script, the `extra` keyword + arguments are passed to the :meth:`~clickpkg.Command.main` function of + the command. + + This returns a :class:`Result` object. + + :param cli: the command to invoke + :param args: the arguments to invoke. It may be given as an iterable + or a string. When given as string it will be interpreted + as a Unix shell command. More details at + :func:`shlex.split`. + :param input: the input data for `sys.stdin`. + :param env: the environment overrides. + :param catch_exceptions: Whether to catch any other exceptions than + ``SystemExit``. + :param extra: the keyword arguments to pass to :meth:`main`. + :param color: whether the output should contain color codes. The + application can still override this explicitly. + + .. versionchanged:: 8.0 + The result object has the ``return_value`` attribute with + the value returned from the invoked command. + + .. versionchanged:: 4.0 + Added the ``color`` parameter. + + .. versionchanged:: 3.0 + Added the ``catch_exceptions`` parameter. + + .. versionchanged:: 3.0 + The result object has the ``exc_info`` attribute with the + traceback if available. + """ + exc_info = None + with self.isolation(input=input, env=env, color=color) as outstreams: + return_value = None + exception: t.Optional[BaseException] = None + exit_code = 0 + + if isinstance(args, str): + args = shlex.split(args) + + try: + prog_name = extra.pop("prog_name") + except KeyError: + prog_name = self.get_default_prog_name(cli) + + try: + return_value = cli.main(args=args or (), prog_name=prog_name, **extra) + except SystemExit as e: + exc_info = sys.exc_info() + e_code = t.cast(t.Optional[t.Union[int, t.Any]], e.code) + + if e_code is None: + e_code = 0 + + if e_code != 0: + exception = e + + if not isinstance(e_code, int): + sys.stdout.write(str(e_code)) + sys.stdout.write("\n") + e_code = 1 + + exit_code = e_code + + except Exception as e: + if not catch_exceptions: + raise + exception = e + exit_code = 1 + exc_info = sys.exc_info() + finally: + sys.stdout.flush() + stdout = outstreams[0].getvalue() + if self.mix_stderr: + stderr = None + else: + stderr = outstreams[1].getvalue() # type: ignore + + return Result( + runner=self, + stdout_bytes=stdout, + stderr_bytes=stderr, + return_value=return_value, + exit_code=exit_code, + exception=exception, + exc_info=exc_info, # type: ignore + ) + + @contextlib.contextmanager + def isolated_filesystem( + self, temp_dir: t.Optional[t.Union[str, os.PathLike]] = None + ) -> t.Iterator[str]: + """A context manager that creates a temporary directory and + changes the current working directory to it. This isolates tests + that affect the contents of the CWD to prevent them from + interfering with each other. + + :param temp_dir: Create the temporary directory under this + directory. If given, the created directory is not removed + when exiting. + + .. versionchanged:: 8.0 + Added the ``temp_dir`` parameter. + """ + cwd = os.getcwd() + t = tempfile.mkdtemp(dir=temp_dir) + os.chdir(t) + + try: + yield t + finally: + os.chdir(cwd) + + if temp_dir is None: + try: + shutil.rmtree(t) + except OSError: # noqa: B014 + pass diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/types.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/types.py new file mode 100644 index 00000000..103d2182 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/types.py @@ -0,0 +1,1052 @@ +import os +import stat +import typing as t +from datetime import datetime +from gettext import gettext as _ +from gettext import ngettext + +from ._compat import _get_argv_encoding +from ._compat import get_filesystem_encoding +from ._compat import open_stream +from .exceptions import BadParameter +from .utils import LazyFile +from .utils import safecall + +if t.TYPE_CHECKING: + import typing_extensions as te + from .core import Context + from .core import Parameter + from .shell_completion import CompletionItem + + +class ParamType: + """Represents the type of a parameter. Validates and converts values + from the command line or Python into the correct type. + + To implement a custom type, subclass and implement at least the + following: + + - The :attr:`name` class attribute must be set. + - Calling an instance of the type with ``None`` must return + ``None``. This is already implemented by default. + - :meth:`convert` must convert string values to the correct type. + - :meth:`convert` must accept values that are already the correct + type. + - It must be able to convert a value if the ``ctx`` and ``param`` + arguments are ``None``. This can occur when converting prompt + input. + """ + + is_composite: t.ClassVar[bool] = False + arity: t.ClassVar[int] = 1 + + #: the descriptive name of this type + name: str + + #: if a list of this type is expected and the value is pulled from a + #: string environment variable, this is what splits it up. `None` + #: means any whitespace. For all parameters the general rule is that + #: whitespace splits them up. The exception are paths and files which + #: are split by ``os.path.pathsep`` by default (":" on Unix and ";" on + #: Windows). + envvar_list_splitter: t.ClassVar[t.Optional[str]] = None + + def to_info_dict(self) -> t.Dict[str, t.Any]: + """Gather information that could be useful for a tool generating + user-facing documentation. + + Use :meth:`click.Context.to_info_dict` to traverse the entire + CLI structure. + + .. versionadded:: 8.0 + """ + # The class name without the "ParamType" suffix. + param_type = type(self).__name__.partition("ParamType")[0] + param_type = param_type.partition("ParameterType")[0] + return {"param_type": param_type, "name": self.name} + + def __call__( + self, + value: t.Any, + param: t.Optional["Parameter"] = None, + ctx: t.Optional["Context"] = None, + ) -> t.Any: + if value is not None: + return self.convert(value, param, ctx) + + def get_metavar(self, param: "Parameter") -> t.Optional[str]: + """Returns the metavar default for this param if it provides one.""" + + def get_missing_message(self, param: "Parameter") -> t.Optional[str]: + """Optionally might return extra information about a missing + parameter. + + .. versionadded:: 2.0 + """ + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + """Convert the value to the correct type. This is not called if + the value is ``None`` (the missing value). + + This must accept string values from the command line, as well as + values that are already the correct type. It may also convert + other compatible types. + + The ``param`` and ``ctx`` arguments may be ``None`` in certain + situations, such as when converting prompt input. + + If the value cannot be converted, call :meth:`fail` with a + descriptive message. + + :param value: The value to convert. + :param param: The parameter that is using this type to convert + its value. May be ``None``. + :param ctx: The current context that arrived at this value. May + be ``None``. + """ + return value + + def split_envvar_value(self, rv: str) -> t.Sequence[str]: + """Given a value from an environment variable this splits it up + into small chunks depending on the defined envvar list splitter. + + If the splitter is set to `None`, which means that whitespace splits, + then leading and trailing whitespace is ignored. Otherwise, leading + and trailing splitters usually lead to empty items being included. + """ + return (rv or "").split(self.envvar_list_splitter) + + def fail( + self, + message: str, + param: t.Optional["Parameter"] = None, + ctx: t.Optional["Context"] = None, + ) -> "t.NoReturn": + """Helper method to fail with an invalid value message.""" + raise BadParameter(message, ctx=ctx, param=param) + + def shell_complete( + self, ctx: "Context", param: "Parameter", incomplete: str + ) -> t.List["CompletionItem"]: + """Return a list of + :class:`~click.shell_completion.CompletionItem` objects for the + incomplete value. Most types do not provide completions, but + some do, and this allows custom types to provide custom + completions as well. + + :param ctx: Invocation context for this command. + :param param: The parameter that is requesting completion. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + return [] + + +class CompositeParamType(ParamType): + is_composite = True + + @property + def arity(self) -> int: # type: ignore + raise NotImplementedError() + + +class FuncParamType(ParamType): + def __init__(self, func: t.Callable[[t.Any], t.Any]) -> None: + self.name = func.__name__ + self.func = func + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict["func"] = self.func + return info_dict + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + try: + return self.func(value) + except ValueError: + try: + value = str(value) + except UnicodeError: + value = value.decode("utf-8", "replace") + + self.fail(value, param, ctx) + + +class UnprocessedParamType(ParamType): + name = "text" + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + return value + + def __repr__(self) -> str: + return "UNPROCESSED" + + +class StringParamType(ParamType): + name = "text" + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + if isinstance(value, bytes): + enc = _get_argv_encoding() + try: + value = value.decode(enc) + except UnicodeError: + fs_enc = get_filesystem_encoding() + if fs_enc != enc: + try: + value = value.decode(fs_enc) + except UnicodeError: + value = value.decode("utf-8", "replace") + else: + value = value.decode("utf-8", "replace") + return value + return str(value) + + def __repr__(self) -> str: + return "STRING" + + +class Choice(ParamType): + """The choice type allows a value to be checked against a fixed set + of supported values. All of these values have to be strings. + + You should only pass a list or tuple of choices. Other iterables + (like generators) may lead to surprising results. + + The resulting value will always be one of the originally passed choices + regardless of ``case_sensitive`` or any ``ctx.token_normalize_func`` + being specified. + + See :ref:`choice-opts` for an example. + + :param case_sensitive: Set to false to make choices case + insensitive. Defaults to true. + """ + + name = "choice" + + def __init__(self, choices: t.Sequence[str], case_sensitive: bool = True) -> None: + self.choices = choices + self.case_sensitive = case_sensitive + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict["choices"] = self.choices + info_dict["case_sensitive"] = self.case_sensitive + return info_dict + + def get_metavar(self, param: "Parameter") -> str: + choices_str = "|".join(self.choices) + + # Use curly braces to indicate a required argument. + if param.required and param.param_type_name == "argument": + return f"{{{choices_str}}}" + + # Use square braces to indicate an option or optional argument. + return f"[{choices_str}]" + + def get_missing_message(self, param: "Parameter") -> str: + return _("Choose from:\n\t{choices}").format(choices=",\n\t".join(self.choices)) + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + # Match through normalization and case sensitivity + # first do token_normalize_func, then lowercase + # preserve original `value` to produce an accurate message in + # `self.fail` + normed_value = value + normed_choices = {choice: choice for choice in self.choices} + + if ctx is not None and ctx.token_normalize_func is not None: + normed_value = ctx.token_normalize_func(value) + normed_choices = { + ctx.token_normalize_func(normed_choice): original + for normed_choice, original in normed_choices.items() + } + + if not self.case_sensitive: + normed_value = normed_value.casefold() + normed_choices = { + normed_choice.casefold(): original + for normed_choice, original in normed_choices.items() + } + + if normed_value in normed_choices: + return normed_choices[normed_value] + + choices_str = ", ".join(map(repr, self.choices)) + self.fail( + ngettext( + "{value!r} is not {choice}.", + "{value!r} is not one of {choices}.", + len(self.choices), + ).format(value=value, choice=choices_str, choices=choices_str), + param, + ctx, + ) + + def __repr__(self) -> str: + return f"Choice({list(self.choices)})" + + def shell_complete( + self, ctx: "Context", param: "Parameter", incomplete: str + ) -> t.List["CompletionItem"]: + """Complete choices that start with the incomplete value. + + :param ctx: Invocation context for this command. + :param param: The parameter that is requesting completion. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + str_choices = map(str, self.choices) + + if self.case_sensitive: + matched = (c for c in str_choices if c.startswith(incomplete)) + else: + incomplete = incomplete.lower() + matched = (c for c in str_choices if c.lower().startswith(incomplete)) + + return [CompletionItem(c) for c in matched] + + +class DateTime(ParamType): + """The DateTime type converts date strings into `datetime` objects. + + The format strings which are checked are configurable, but default to some + common (non-timezone aware) ISO 8601 formats. + + When specifying *DateTime* formats, you should only pass a list or a tuple. + Other iterables, like generators, may lead to surprising results. + + The format strings are processed using ``datetime.strptime``, and this + consequently defines the format strings which are allowed. + + Parsing is tried using each format, in order, and the first format which + parses successfully is used. + + :param formats: A list or tuple of date format strings, in the order in + which they should be tried. Defaults to + ``'%Y-%m-%d'``, ``'%Y-%m-%dT%H:%M:%S'``, + ``'%Y-%m-%d %H:%M:%S'``. + """ + + name = "datetime" + + def __init__(self, formats: t.Optional[t.Sequence[str]] = None): + self.formats = formats or ["%Y-%m-%d", "%Y-%m-%dT%H:%M:%S", "%Y-%m-%d %H:%M:%S"] + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict["formats"] = self.formats + return info_dict + + def get_metavar(self, param: "Parameter") -> str: + return f"[{'|'.join(self.formats)}]" + + def _try_to_convert_date(self, value: t.Any, format: str) -> t.Optional[datetime]: + try: + return datetime.strptime(value, format) + except ValueError: + return None + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + if isinstance(value, datetime): + return value + + for format in self.formats: + converted = self._try_to_convert_date(value, format) + + if converted is not None: + return converted + + formats_str = ", ".join(map(repr, self.formats)) + self.fail( + ngettext( + "{value!r} does not match the format {format}.", + "{value!r} does not match the formats {formats}.", + len(self.formats), + ).format(value=value, format=formats_str, formats=formats_str), + param, + ctx, + ) + + def __repr__(self) -> str: + return "DateTime" + + +class _NumberParamTypeBase(ParamType): + _number_class: t.ClassVar[t.Type] + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + try: + return self._number_class(value) + except ValueError: + self.fail( + _("{value!r} is not a valid {number_type}.").format( + value=value, number_type=self.name + ), + param, + ctx, + ) + + +class _NumberRangeBase(_NumberParamTypeBase): + def __init__( + self, + min: t.Optional[float] = None, + max: t.Optional[float] = None, + min_open: bool = False, + max_open: bool = False, + clamp: bool = False, + ) -> None: + self.min = min + self.max = max + self.min_open = min_open + self.max_open = max_open + self.clamp = clamp + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict.update( + min=self.min, + max=self.max, + min_open=self.min_open, + max_open=self.max_open, + clamp=self.clamp, + ) + return info_dict + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + import operator + + rv = super().convert(value, param, ctx) + lt_min: bool = self.min is not None and ( + operator.le if self.min_open else operator.lt + )(rv, self.min) + gt_max: bool = self.max is not None and ( + operator.ge if self.max_open else operator.gt + )(rv, self.max) + + if self.clamp: + if lt_min: + return self._clamp(self.min, 1, self.min_open) # type: ignore + + if gt_max: + return self._clamp(self.max, -1, self.max_open) # type: ignore + + if lt_min or gt_max: + self.fail( + _("{value} is not in the range {range}.").format( + value=rv, range=self._describe_range() + ), + param, + ctx, + ) + + return rv + + def _clamp(self, bound: float, dir: "te.Literal[1, -1]", open: bool) -> float: + """Find the valid value to clamp to bound in the given + direction. + + :param bound: The boundary value. + :param dir: 1 or -1 indicating the direction to move. + :param open: If true, the range does not include the bound. + """ + raise NotImplementedError + + def _describe_range(self) -> str: + """Describe the range for use in help text.""" + if self.min is None: + op = "<" if self.max_open else "<=" + return f"x{op}{self.max}" + + if self.max is None: + op = ">" if self.min_open else ">=" + return f"x{op}{self.min}" + + lop = "<" if self.min_open else "<=" + rop = "<" if self.max_open else "<=" + return f"{self.min}{lop}x{rop}{self.max}" + + def __repr__(self) -> str: + clamp = " clamped" if self.clamp else "" + return f"<{type(self).__name__} {self._describe_range()}{clamp}>" + + +class IntParamType(_NumberParamTypeBase): + name = "integer" + _number_class = int + + def __repr__(self) -> str: + return "INT" + + +class IntRange(_NumberRangeBase, IntParamType): + """Restrict an :data:`click.INT` value to a range of accepted + values. See :ref:`ranges`. + + If ``min`` or ``max`` are not passed, any value is accepted in that + direction. If ``min_open`` or ``max_open`` are enabled, the + corresponding boundary is not included in the range. + + If ``clamp`` is enabled, a value outside the range is clamped to the + boundary instead of failing. + + .. versionchanged:: 8.0 + Added the ``min_open`` and ``max_open`` parameters. + """ + + name = "integer range" + + def _clamp( # type: ignore + self, bound: int, dir: "te.Literal[1, -1]", open: bool + ) -> int: + if not open: + return bound + + return bound + dir + + +class FloatParamType(_NumberParamTypeBase): + name = "float" + _number_class = float + + def __repr__(self) -> str: + return "FLOAT" + + +class FloatRange(_NumberRangeBase, FloatParamType): + """Restrict a :data:`click.FLOAT` value to a range of accepted + values. See :ref:`ranges`. + + If ``min`` or ``max`` are not passed, any value is accepted in that + direction. If ``min_open`` or ``max_open`` are enabled, the + corresponding boundary is not included in the range. + + If ``clamp`` is enabled, a value outside the range is clamped to the + boundary instead of failing. This is not supported if either + boundary is marked ``open``. + + .. versionchanged:: 8.0 + Added the ``min_open`` and ``max_open`` parameters. + """ + + name = "float range" + + def __init__( + self, + min: t.Optional[float] = None, + max: t.Optional[float] = None, + min_open: bool = False, + max_open: bool = False, + clamp: bool = False, + ) -> None: + super().__init__( + min=min, max=max, min_open=min_open, max_open=max_open, clamp=clamp + ) + + if (min_open or max_open) and clamp: + raise TypeError("Clamping is not supported for open bounds.") + + def _clamp(self, bound: float, dir: "te.Literal[1, -1]", open: bool) -> float: + if not open: + return bound + + # Could use Python 3.9's math.nextafter here, but clamping an + # open float range doesn't seem to be particularly useful. It's + # left up to the user to write a callback to do it if needed. + raise RuntimeError("Clamping is not supported for open bounds.") + + +class BoolParamType(ParamType): + name = "boolean" + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + if value in {False, True}: + return bool(value) + + norm = value.strip().lower() + + if norm in {"1", "true", "t", "yes", "y", "on"}: + return True + + if norm in {"0", "false", "f", "no", "n", "off"}: + return False + + self.fail( + _("{value!r} is not a valid boolean.").format(value=value), param, ctx + ) + + def __repr__(self) -> str: + return "BOOL" + + +class UUIDParameterType(ParamType): + name = "uuid" + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + import uuid + + if isinstance(value, uuid.UUID): + return value + + value = value.strip() + + try: + return uuid.UUID(value) + except ValueError: + self.fail( + _("{value!r} is not a valid UUID.").format(value=value), param, ctx + ) + + def __repr__(self) -> str: + return "UUID" + + +class File(ParamType): + """Declares a parameter to be a file for reading or writing. The file + is automatically closed once the context tears down (after the command + finished working). + + Files can be opened for reading or writing. The special value ``-`` + indicates stdin or stdout depending on the mode. + + By default, the file is opened for reading text data, but it can also be + opened in binary mode or for writing. The encoding parameter can be used + to force a specific encoding. + + The `lazy` flag controls if the file should be opened immediately or upon + first IO. The default is to be non-lazy for standard input and output + streams as well as files opened for reading, `lazy` otherwise. When opening a + file lazily for reading, it is still opened temporarily for validation, but + will not be held open until first IO. lazy is mainly useful when opening + for writing to avoid creating the file until it is needed. + + Starting with Click 2.0, files can also be opened atomically in which + case all writes go into a separate file in the same folder and upon + completion the file will be moved over to the original location. This + is useful if a file regularly read by other users is modified. + + See :ref:`file-args` for more information. + """ + + name = "filename" + envvar_list_splitter = os.path.pathsep + + def __init__( + self, + mode: str = "r", + encoding: t.Optional[str] = None, + errors: t.Optional[str] = "strict", + lazy: t.Optional[bool] = None, + atomic: bool = False, + ) -> None: + self.mode = mode + self.encoding = encoding + self.errors = errors + self.lazy = lazy + self.atomic = atomic + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict.update(mode=self.mode, encoding=self.encoding) + return info_dict + + def resolve_lazy_flag(self, value: t.Any) -> bool: + if self.lazy is not None: + return self.lazy + if value == "-": + return False + elif "w" in self.mode: + return True + return False + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + try: + if hasattr(value, "read") or hasattr(value, "write"): + return value + + lazy = self.resolve_lazy_flag(value) + + if lazy: + f: t.IO = t.cast( + t.IO, + LazyFile( + value, self.mode, self.encoding, self.errors, atomic=self.atomic + ), + ) + + if ctx is not None: + ctx.call_on_close(f.close_intelligently) # type: ignore + + return f + + f, should_close = open_stream( + value, self.mode, self.encoding, self.errors, atomic=self.atomic + ) + + # If a context is provided, we automatically close the file + # at the end of the context execution (or flush out). If a + # context does not exist, it's the caller's responsibility to + # properly close the file. This for instance happens when the + # type is used with prompts. + if ctx is not None: + if should_close: + ctx.call_on_close(safecall(f.close)) + else: + ctx.call_on_close(safecall(f.flush)) + + return f + except OSError as e: # noqa: B014 + self.fail(f"{os.fsdecode(value)!r}: {e.strerror}", param, ctx) + + def shell_complete( + self, ctx: "Context", param: "Parameter", incomplete: str + ) -> t.List["CompletionItem"]: + """Return a special completion marker that tells the completion + system to use the shell to provide file path completions. + + :param ctx: Invocation context for this command. + :param param: The parameter that is requesting completion. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + return [CompletionItem(incomplete, type="file")] + + +class Path(ParamType): + """The path type is similar to the :class:`File` type but it performs + different checks. First of all, instead of returning an open file + handle it returns just the filename. Secondly, it can perform various + basic checks about what the file or directory should be. + + :param exists: if set to true, the file or directory needs to exist for + this value to be valid. If this is not required and a + file does indeed not exist, then all further checks are + silently skipped. + :param file_okay: controls if a file is a possible value. + :param dir_okay: controls if a directory is a possible value. + :param writable: if true, a writable check is performed. + :param readable: if true, a readable check is performed. + :param resolve_path: if this is true, then the path is fully resolved + before the value is passed onwards. This means + that it's absolute and symlinks are resolved. It + will not expand a tilde-prefix, as this is + supposed to be done by the shell only. + :param allow_dash: If this is set to `True`, a single dash to indicate + standard streams is permitted. + :param path_type: Convert the incoming path value to this type. If + ``None``, keep Python's default, which is ``str``. Useful to + convert to :class:`pathlib.Path`. + + .. versionchanged:: 8.0 + Allow passing ``type=pathlib.Path``. + + .. versionchanged:: 6.0 + Added the ``allow_dash`` parameter. + """ + + envvar_list_splitter = os.path.pathsep + + def __init__( + self, + exists: bool = False, + file_okay: bool = True, + dir_okay: bool = True, + writable: bool = False, + readable: bool = True, + resolve_path: bool = False, + allow_dash: bool = False, + path_type: t.Optional[t.Type] = None, + ): + self.exists = exists + self.file_okay = file_okay + self.dir_okay = dir_okay + self.writable = writable + self.readable = readable + self.resolve_path = resolve_path + self.allow_dash = allow_dash + self.type = path_type + + if self.file_okay and not self.dir_okay: + self.name = _("file") + elif self.dir_okay and not self.file_okay: + self.name = _("directory") + else: + self.name = _("path") + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict.update( + exists=self.exists, + file_okay=self.file_okay, + dir_okay=self.dir_okay, + writable=self.writable, + readable=self.readable, + allow_dash=self.allow_dash, + ) + return info_dict + + def coerce_path_result(self, rv: t.Any) -> t.Any: + if self.type is not None and not isinstance(rv, self.type): + if self.type is str: + rv = os.fsdecode(rv) + elif self.type is bytes: + rv = os.fsencode(rv) + else: + rv = self.type(rv) + + return rv + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + rv = value + + is_dash = self.file_okay and self.allow_dash and rv in (b"-", "-") + + if not is_dash: + if self.resolve_path: + # os.path.realpath doesn't resolve symlinks on Windows + # until Python 3.8. Use pathlib for now. + import pathlib + + rv = os.fsdecode(pathlib.Path(rv).resolve()) + + try: + st = os.stat(rv) + except OSError: + if not self.exists: + return self.coerce_path_result(rv) + self.fail( + _("{name} {filename!r} does not exist.").format( + name=self.name.title(), filename=os.fsdecode(value) + ), + param, + ctx, + ) + + if not self.file_okay and stat.S_ISREG(st.st_mode): + self.fail( + _("{name} {filename!r} is a file.").format( + name=self.name.title(), filename=os.fsdecode(value) + ), + param, + ctx, + ) + if not self.dir_okay and stat.S_ISDIR(st.st_mode): + self.fail( + _("{name} {filename!r} is a directory.").format( + name=self.name.title(), filename=os.fsdecode(value) + ), + param, + ctx, + ) + if self.writable and not os.access(rv, os.W_OK): + self.fail( + _("{name} {filename!r} is not writable.").format( + name=self.name.title(), filename=os.fsdecode(value) + ), + param, + ctx, + ) + if self.readable and not os.access(rv, os.R_OK): + self.fail( + _("{name} {filename!r} is not readable.").format( + name=self.name.title(), filename=os.fsdecode(value) + ), + param, + ctx, + ) + + return self.coerce_path_result(rv) + + def shell_complete( + self, ctx: "Context", param: "Parameter", incomplete: str + ) -> t.List["CompletionItem"]: + """Return a special completion marker that tells the completion + system to use the shell to provide path completions for only + directories or any paths. + + :param ctx: Invocation context for this command. + :param param: The parameter that is requesting completion. + :param incomplete: Value being completed. May be empty. + + .. versionadded:: 8.0 + """ + from click.shell_completion import CompletionItem + + type = "dir" if self.dir_okay and not self.file_okay else "file" + return [CompletionItem(incomplete, type=type)] + + +class Tuple(CompositeParamType): + """The default behavior of Click is to apply a type on a value directly. + This works well in most cases, except for when `nargs` is set to a fixed + count and different types should be used for different items. In this + case the :class:`Tuple` type can be used. This type can only be used + if `nargs` is set to a fixed number. + + For more information see :ref:`tuple-type`. + + This can be selected by using a Python tuple literal as a type. + + :param types: a list of types that should be used for the tuple items. + """ + + def __init__(self, types: t.Sequence[t.Union[t.Type, ParamType]]) -> None: + self.types = [convert_type(ty) for ty in types] + + def to_info_dict(self) -> t.Dict[str, t.Any]: + info_dict = super().to_info_dict() + info_dict["types"] = [t.to_info_dict() for t in self.types] + return info_dict + + @property + def name(self) -> str: # type: ignore + return f"<{' '.join(ty.name for ty in self.types)}>" + + @property + def arity(self) -> int: # type: ignore + return len(self.types) + + def convert( + self, value: t.Any, param: t.Optional["Parameter"], ctx: t.Optional["Context"] + ) -> t.Any: + len_type = len(self.types) + len_value = len(value) + + if len_value != len_type: + self.fail( + ngettext( + "{len_type} values are required, but {len_value} was given.", + "{len_type} values are required, but {len_value} were given.", + len_value, + ).format(len_type=len_type, len_value=len_value), + param=param, + ctx=ctx, + ) + + return tuple(ty(x, param, ctx) for ty, x in zip(self.types, value)) + + +def convert_type(ty: t.Optional[t.Any], default: t.Optional[t.Any] = None) -> ParamType: + """Find the most appropriate :class:`ParamType` for the given Python + type. If the type isn't provided, it can be inferred from a default + value. + """ + guessed_type = False + + if ty is None and default is not None: + if isinstance(default, (tuple, list)): + # If the default is empty, ty will remain None and will + # return STRING. + if default: + item = default[0] + + # A tuple of tuples needs to detect the inner types. + # Can't call convert recursively because that would + # incorrectly unwind the tuple to a single type. + if isinstance(item, (tuple, list)): + ty = tuple(map(type, item)) + else: + ty = type(item) + else: + ty = type(default) + + guessed_type = True + + if isinstance(ty, tuple): + return Tuple(ty) + + if isinstance(ty, ParamType): + return ty + + if ty is str or ty is None: + return STRING + + if ty is int: + return INT + + if ty is float: + return FLOAT + + if ty is bool: + return BOOL + + if guessed_type: + return STRING + + if __debug__: + try: + if issubclass(ty, ParamType): + raise AssertionError( + f"Attempted to use an uninstantiated parameter type ({ty})." + ) + except TypeError: + # ty is an instance (correct), so issubclass fails. + pass + + return FuncParamType(ty) + + +#: A dummy parameter type that just does nothing. From a user's +#: perspective this appears to just be the same as `STRING` but +#: internally no string conversion takes place if the input was bytes. +#: This is usually useful when working with file paths as they can +#: appear in bytes and unicode. +#: +#: For path related uses the :class:`Path` type is a better choice but +#: there are situations where an unprocessed type is useful which is why +#: it is is provided. +#: +#: .. versionadded:: 4.0 +UNPROCESSED = UnprocessedParamType() + +#: A unicode string parameter type which is the implicit default. This +#: can also be selected by using ``str`` as type. +STRING = StringParamType() + +#: An integer parameter. This can also be selected by using ``int`` as +#: type. +INT = IntParamType() + +#: A floating point value parameter. This can also be selected by using +#: ``float`` as type. +FLOAT = FloatParamType() + +#: A boolean parameter. This is the default for boolean flags. This can +#: also be selected by using ``bool`` as a type. +BOOL = BoolParamType() + +#: A UUID parameter. +UUID = UUIDParameterType() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/click/utils.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/utils.py new file mode 100644 index 00000000..16033d62 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/click/utils.py @@ -0,0 +1,579 @@ +import os +import sys +import typing as t +from functools import update_wrapper +from types import ModuleType + +from ._compat import _default_text_stderr +from ._compat import _default_text_stdout +from ._compat import _find_binary_writer +from ._compat import auto_wrap_for_ansi +from ._compat import binary_streams +from ._compat import get_filesystem_encoding +from ._compat import open_stream +from ._compat import should_strip_ansi +from ._compat import strip_ansi +from ._compat import text_streams +from ._compat import WIN +from .globals import resolve_color_default + +if t.TYPE_CHECKING: + import typing_extensions as te + +F = t.TypeVar("F", bound=t.Callable[..., t.Any]) + + +def _posixify(name: str) -> str: + return "-".join(name.split()).lower() + + +def safecall(func: F) -> F: + """Wraps a function so that it swallows exceptions.""" + + def wrapper(*args, **kwargs): # type: ignore + try: + return func(*args, **kwargs) + except Exception: + pass + + return update_wrapper(t.cast(F, wrapper), func) + + +def make_str(value: t.Any) -> str: + """Converts a value into a valid string.""" + if isinstance(value, bytes): + try: + return value.decode(get_filesystem_encoding()) + except UnicodeError: + return value.decode("utf-8", "replace") + return str(value) + + +def make_default_short_help(help: str, max_length: int = 45) -> str: + """Returns a condensed version of help string.""" + # Consider only the first paragraph. + paragraph_end = help.find("\n\n") + + if paragraph_end != -1: + help = help[:paragraph_end] + + # Collapse newlines, tabs, and spaces. + words = help.split() + + if not words: + return "" + + # The first paragraph started with a "no rewrap" marker, ignore it. + if words[0] == "\b": + words = words[1:] + + total_length = 0 + last_index = len(words) - 1 + + for i, word in enumerate(words): + total_length += len(word) + (i > 0) + + if total_length > max_length: # too long, truncate + break + + if word[-1] == ".": # sentence end, truncate without "..." + return " ".join(words[: i + 1]) + + if total_length == max_length and i != last_index: + break # not at sentence end, truncate with "..." + else: + return " ".join(words) # no truncation needed + + # Account for the length of the suffix. + total_length += len("...") + + # remove words until the length is short enough + while i > 0: + total_length -= len(words[i]) + (i > 0) + + if total_length <= max_length: + break + + i -= 1 + + return " ".join(words[:i]) + "..." + + +class LazyFile: + """A lazy file works like a regular file but it does not fully open + the file but it does perform some basic checks early to see if the + filename parameter does make sense. This is useful for safely opening + files for writing. + """ + + def __init__( + self, + filename: str, + mode: str = "r", + encoding: t.Optional[str] = None, + errors: t.Optional[str] = "strict", + atomic: bool = False, + ): + self.name = filename + self.mode = mode + self.encoding = encoding + self.errors = errors + self.atomic = atomic + self._f: t.Optional[t.IO] + + if filename == "-": + self._f, self.should_close = open_stream(filename, mode, encoding, errors) + else: + if "r" in mode: + # Open and close the file in case we're opening it for + # reading so that we can catch at least some errors in + # some cases early. + open(filename, mode).close() + self._f = None + self.should_close = True + + def __getattr__(self, name: str) -> t.Any: + return getattr(self.open(), name) + + def __repr__(self) -> str: + if self._f is not None: + return repr(self._f) + return f"" + + def open(self) -> t.IO: + """Opens the file if it's not yet open. This call might fail with + a :exc:`FileError`. Not handling this error will produce an error + that Click shows. + """ + if self._f is not None: + return self._f + try: + rv, self.should_close = open_stream( + self.name, self.mode, self.encoding, self.errors, atomic=self.atomic + ) + except OSError as e: # noqa: E402 + from .exceptions import FileError + + raise FileError(self.name, hint=e.strerror) from e + self._f = rv + return rv + + def close(self) -> None: + """Closes the underlying file, no matter what.""" + if self._f is not None: + self._f.close() + + def close_intelligently(self) -> None: + """This function only closes the file if it was opened by the lazy + file wrapper. For instance this will never close stdin. + """ + if self.should_close: + self.close() + + def __enter__(self) -> "LazyFile": + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + self.close_intelligently() + + def __iter__(self) -> t.Iterator[t.AnyStr]: + self.open() + return iter(self._f) # type: ignore + + +class KeepOpenFile: + def __init__(self, file: t.IO) -> None: + self._file = file + + def __getattr__(self, name: str) -> t.Any: + return getattr(self._file, name) + + def __enter__(self) -> "KeepOpenFile": + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + pass + + def __repr__(self) -> str: + return repr(self._file) + + def __iter__(self) -> t.Iterator[t.AnyStr]: + return iter(self._file) + + +def echo( + message: t.Optional[t.Any] = None, + file: t.Optional[t.IO] = None, + nl: bool = True, + err: bool = False, + color: t.Optional[bool] = None, +) -> None: + """Print a message and newline to stdout or a file. This should be + used instead of :func:`print` because it provides better support + for different data, files, and environments. + + Compared to :func:`print`, this does the following: + + - Ensures that the output encoding is not misconfigured on Linux. + - Supports Unicode in the Windows console. + - Supports writing to binary outputs, and supports writing bytes + to text outputs. + - Supports colors and styles on Windows. + - Removes ANSI color and style codes if the output does not look + like an interactive terminal. + - Always flushes the output. + + :param message: The string or bytes to output. Other objects are + converted to strings. + :param file: The file to write to. Defaults to ``stdout``. + :param err: Write to ``stderr`` instead of ``stdout``. + :param nl: Print a newline after the message. Enabled by default. + :param color: Force showing or hiding colors and other styles. By + default Click will remove color if the output does not look like + an interactive terminal. + + .. versionchanged:: 6.0 + Support Unicode output on the Windows console. Click does not + modify ``sys.stdout``, so ``sys.stdout.write()`` and ``print()`` + will still not support Unicode. + + .. versionchanged:: 4.0 + Added the ``color`` parameter. + + .. versionadded:: 3.0 + Added the ``err`` parameter. + + .. versionchanged:: 2.0 + Support colors on Windows if colorama is installed. + """ + if file is None: + if err: + file = _default_text_stderr() + else: + file = _default_text_stdout() + + # Convert non bytes/text into the native string type. + if message is not None and not isinstance(message, (str, bytes, bytearray)): + out: t.Optional[t.Union[str, bytes]] = str(message) + else: + out = message + + if nl: + out = out or "" + if isinstance(out, str): + out += "\n" + else: + out += b"\n" + + if not out: + file.flush() + return + + # If there is a message and the value looks like bytes, we manually + # need to find the binary stream and write the message in there. + # This is done separately so that most stream types will work as you + # would expect. Eg: you can write to StringIO for other cases. + if isinstance(out, (bytes, bytearray)): + binary_file = _find_binary_writer(file) + + if binary_file is not None: + file.flush() + binary_file.write(out) + binary_file.flush() + return + + # ANSI style code support. For no message or bytes, nothing happens. + # When outputting to a file instead of a terminal, strip codes. + else: + color = resolve_color_default(color) + + if should_strip_ansi(file, color): + out = strip_ansi(out) + elif WIN: + if auto_wrap_for_ansi is not None: + file = auto_wrap_for_ansi(file) # type: ignore + elif not color: + out = strip_ansi(out) + + file.write(out) # type: ignore + file.flush() + + +def get_binary_stream(name: "te.Literal['stdin', 'stdout', 'stderr']") -> t.BinaryIO: + """Returns a system stream for byte processing. + + :param name: the name of the stream to open. Valid names are ``'stdin'``, + ``'stdout'`` and ``'stderr'`` + """ + opener = binary_streams.get(name) + if opener is None: + raise TypeError(f"Unknown standard stream '{name}'") + return opener() + + +def get_text_stream( + name: "te.Literal['stdin', 'stdout', 'stderr']", + encoding: t.Optional[str] = None, + errors: t.Optional[str] = "strict", +) -> t.TextIO: + """Returns a system stream for text processing. This usually returns + a wrapped stream around a binary stream returned from + :func:`get_binary_stream` but it also can take shortcuts for already + correctly configured streams. + + :param name: the name of the stream to open. Valid names are ``'stdin'``, + ``'stdout'`` and ``'stderr'`` + :param encoding: overrides the detected default encoding. + :param errors: overrides the default error mode. + """ + opener = text_streams.get(name) + if opener is None: + raise TypeError(f"Unknown standard stream '{name}'") + return opener(encoding, errors) + + +def open_file( + filename: str, + mode: str = "r", + encoding: t.Optional[str] = None, + errors: t.Optional[str] = "strict", + lazy: bool = False, + atomic: bool = False, +) -> t.IO: + """This is similar to how the :class:`File` works but for manual + usage. Files are opened non lazy by default. This can open regular + files as well as stdin/stdout if ``'-'`` is passed. + + If stdin/stdout is returned the stream is wrapped so that the context + manager will not close the stream accidentally. This makes it possible + to always use the function like this without having to worry to + accidentally close a standard stream:: + + with open_file(filename) as f: + ... + + .. versionadded:: 3.0 + + :param filename: the name of the file to open (or ``'-'`` for stdin/stdout). + :param mode: the mode in which to open the file. + :param encoding: the encoding to use. + :param errors: the error handling for this file. + :param lazy: can be flipped to true to open the file lazily. + :param atomic: in atomic mode writes go into a temporary file and it's + moved on close. + """ + if lazy: + return t.cast(t.IO, LazyFile(filename, mode, encoding, errors, atomic=atomic)) + f, should_close = open_stream(filename, mode, encoding, errors, atomic=atomic) + if not should_close: + f = t.cast(t.IO, KeepOpenFile(f)) + return f + + +def get_os_args() -> t.Sequence[str]: + """Returns the argument part of ``sys.argv``, removing the first + value which is the name of the script. + + .. deprecated:: 8.0 + Will be removed in Click 8.1. Access ``sys.argv[1:]`` directly + instead. + """ + import warnings + + warnings.warn( + "'get_os_args' is deprecated and will be removed in Click 8.1." + " Access 'sys.argv[1:]' directly instead.", + DeprecationWarning, + stacklevel=2, + ) + return sys.argv[1:] + + +def format_filename( + filename: t.Union[str, bytes, os.PathLike], shorten: bool = False +) -> str: + """Formats a filename for user display. The main purpose of this + function is to ensure that the filename can be displayed at all. This + will decode the filename to unicode if necessary in a way that it will + not fail. Optionally, it can shorten the filename to not include the + full path to the filename. + + :param filename: formats a filename for UI display. This will also convert + the filename into unicode without failing. + :param shorten: this optionally shortens the filename to strip of the + path that leads up to it. + """ + if shorten: + filename = os.path.basename(filename) + + return os.fsdecode(filename) + + +def get_app_dir(app_name: str, roaming: bool = True, force_posix: bool = False) -> str: + r"""Returns the config folder for the application. The default behavior + is to return whatever is most appropriate for the operating system. + + To give you an idea, for an app called ``"Foo Bar"``, something like + the following folders could be returned: + + Mac OS X: + ``~/Library/Application Support/Foo Bar`` + Mac OS X (POSIX): + ``~/.foo-bar`` + Unix: + ``~/.config/foo-bar`` + Unix (POSIX): + ``~/.foo-bar`` + Windows (roaming): + ``C:\Users\\AppData\Roaming\Foo Bar`` + Windows (not roaming): + ``C:\Users\\AppData\Local\Foo Bar`` + + .. versionadded:: 2.0 + + :param app_name: the application name. This should be properly capitalized + and can contain whitespace. + :param roaming: controls if the folder should be roaming or not on Windows. + Has no affect otherwise. + :param force_posix: if this is set to `True` then on any POSIX system the + folder will be stored in the home folder with a leading + dot instead of the XDG config home or darwin's + application support folder. + """ + if WIN: + key = "APPDATA" if roaming else "LOCALAPPDATA" + folder = os.environ.get(key) + if folder is None: + folder = os.path.expanduser("~") + return os.path.join(folder, app_name) + if force_posix: + return os.path.join(os.path.expanduser(f"~/.{_posixify(app_name)}")) + if sys.platform == "darwin": + return os.path.join( + os.path.expanduser("~/Library/Application Support"), app_name + ) + return os.path.join( + os.environ.get("XDG_CONFIG_HOME", os.path.expanduser("~/.config")), + _posixify(app_name), + ) + + +class PacifyFlushWrapper: + """This wrapper is used to catch and suppress BrokenPipeErrors resulting + from ``.flush()`` being called on broken pipe during the shutdown/final-GC + of the Python interpreter. Notably ``.flush()`` is always called on + ``sys.stdout`` and ``sys.stderr``. So as to have minimal impact on any + other cleanup code, and the case where the underlying file is not a broken + pipe, all calls and attributes are proxied. + """ + + def __init__(self, wrapped: t.IO) -> None: + self.wrapped = wrapped + + def flush(self) -> None: + try: + self.wrapped.flush() + except OSError as e: + import errno + + if e.errno != errno.EPIPE: + raise + + def __getattr__(self, attr: str) -> t.Any: + return getattr(self.wrapped, attr) + + +def _detect_program_name( + path: t.Optional[str] = None, _main: ModuleType = sys.modules["__main__"] +) -> str: + """Determine the command used to run the program, for use in help + text. If a file or entry point was executed, the file name is + returned. If ``python -m`` was used to execute a module or package, + ``python -m name`` is returned. + + This doesn't try to be too precise, the goal is to give a concise + name for help text. Files are only shown as their name without the + path. ``python`` is only shown for modules, and the full path to + ``sys.executable`` is not shown. + + :param path: The Python file being executed. Python puts this in + ``sys.argv[0]``, which is used by default. + :param _main: The ``__main__`` module. This should only be passed + during internal testing. + + .. versionadded:: 8.0 + Based on command args detection in the Werkzeug reloader. + + :meta private: + """ + if not path: + path = sys.argv[0] + + # The value of __package__ indicates how Python was called. It may + # not exist if a setuptools script is installed as an egg. It may be + # set incorrectly for entry points created with pip on Windows. + if getattr(_main, "__package__", None) is None or ( + os.name == "nt" + and _main.__package__ == "" + and not os.path.exists(path) + and os.path.exists(f"{path}.exe") + ): + # Executed a file, like "python app.py". + return os.path.basename(path) + + # Executed a module, like "python -m example". + # Rewritten by Python from "-m script" to "/path/to/script.py". + # Need to look at main module to determine how it was executed. + py_module = t.cast(str, _main.__package__) + name = os.path.splitext(os.path.basename(path))[0] + + # A submodule like "example.cli". + if name != "__main__": + py_module = f"{py_module}.{name}" + + return f"python -m {py_module.lstrip('.')}" + + +def _expand_args( + args: t.Iterable[str], + *, + user: bool = True, + env: bool = True, + glob_recursive: bool = True, +) -> t.List[str]: + """Simulate Unix shell expansion with Python functions. + + See :func:`glob.glob`, :func:`os.path.expanduser`, and + :func:`os.path.expandvars`. + + This intended for use on Windows, where the shell does not do any + expansion. It may not exactly match what a Unix shell would do. + + :param args: List of command line arguments to expand. + :param user: Expand user home directory. + :param env: Expand environment variables. + :param glob_recursive: ``**`` matches directories recursively. + + .. versionadded:: 8.0 + + :meta private: + """ + from glob import glob + + out = [] + + for arg in args: + if user: + arg = os.path.expanduser(arg) + + if env: + arg = os.path.expandvars(arg) + + matches = glob(arg, recursive=glob_recursive) + + if not matches: + out.append(arg) + else: + out.extend(matches) + + return out diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/INSTALLER b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/INSTALLER new file mode 100644 index 00000000..a1b589e3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/INSTALLER @@ -0,0 +1 @@ +pip diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/LICENSE.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/LICENSE.txt new file mode 100644 index 00000000..3105888e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/LICENSE.txt @@ -0,0 +1,27 @@ +Copyright (c) 2010 Jonathan Hartley +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +* 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. + +* Neither the name of the copyright holders, nor those 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/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/METADATA b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/METADATA new file mode 100644 index 00000000..2a175c26 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/METADATA @@ -0,0 +1,415 @@ +Metadata-Version: 2.1 +Name: colorama +Version: 0.4.4 +Summary: Cross-platform colored terminal text. +Home-page: https://github.com/tartley/colorama +Author: Jonathan Hartley +Author-email: tartley@tartley.com +Maintainer: Arnon Yaari +License: BSD +Keywords: color colour terminal text ansi windows crossplatform xplatform +Platform: UNKNOWN +Classifier: Development Status :: 5 - Production/Stable +Classifier: Environment :: Console +Classifier: Intended Audience :: Developers +Classifier: License :: OSI Approved :: BSD License +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.5 +Classifier: Programming Language :: Python :: 3.6 +Classifier: Programming Language :: Python :: 3.7 +Classifier: Programming Language :: Python :: 3.8 +Classifier: Programming Language :: Python :: Implementation :: CPython +Classifier: Programming Language :: Python :: Implementation :: PyPy +Classifier: Topic :: Terminals +Requires-Python: >=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.* + +.. image:: https://img.shields.io/pypi/v/colorama.svg + :target: https://pypi.org/project/colorama/ + :alt: Latest Version + +.. image:: https://img.shields.io/pypi/pyversions/colorama.svg + :target: https://pypi.org/project/colorama/ + :alt: Supported Python versions + +.. image:: https://travis-ci.org/tartley/colorama.svg?branch=master + :target: https://travis-ci.org/tartley/colorama + :alt: Build Status + +Colorama +======== + +Makes ANSI escape character sequences (for producing colored terminal text and +cursor positioning) work under MS Windows. + +.. |donate| image:: https://www.paypalobjects.com/en_US/i/btn/btn_donate_SM.gif + :target: https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=2MZ9D2GMLYCUJ&item_name=Colorama¤cy_code=USD + :alt: Donate with Paypal + +`PyPI for releases `_ · +`Github for source `_ · +`Colorama for enterprise on Tidelift `_ + +If you find Colorama useful, please |donate| to the authors. Thank you! + + +Installation +------------ + +.. code-block:: bash + + pip install colorama + # or + conda install -c anaconda colorama + + +Description +----------- + +ANSI escape character sequences have long been used to produce colored terminal +text and cursor positioning on Unix and Macs. Colorama makes this work on +Windows, too, by wrapping ``stdout``, stripping ANSI sequences it finds (which +would appear as gobbledygook in the output), and converting them into the +appropriate win32 calls to modify the state of the terminal. On other platforms, +Colorama does nothing. + +This has the upshot of providing a simple cross-platform API for printing +colored terminal text from Python, and has the happy side-effect that existing +applications or libraries which use ANSI sequences to produce colored output on +Linux or Macs can now also work on Windows, simply by calling +``colorama.init()``. + +An alternative approach is to install ``ansi.sys`` on Windows machines, which +provides the same behaviour for all applications running in terminals. Colorama +is intended for situations where that isn't easy (e.g., maybe your app doesn't +have an installer.) + +Demo scripts in the source code repository print some colored text using +ANSI sequences. Compare their output under Gnome-terminal's built in ANSI +handling, versus on Windows Command-Prompt using Colorama: + +.. image:: https://github.com/tartley/colorama/raw/master/screenshots/ubuntu-demo.png + :width: 661 + :height: 357 + :alt: ANSI sequences on Ubuntu under gnome-terminal. + +.. image:: https://github.com/tartley/colorama/raw/master/screenshots/windows-demo.png + :width: 668 + :height: 325 + :alt: Same ANSI sequences on Windows, using Colorama. + +These screenshots show that, on Windows, Colorama does not support ANSI 'dim +text'; it looks the same as 'normal text'. + +Usage +----- + +Initialisation +.............. + +Applications should initialise Colorama using: + +.. code-block:: python + + from colorama import init + init() + +On Windows, calling ``init()`` will filter ANSI escape sequences out of any +text sent to ``stdout`` or ``stderr``, and replace them with equivalent Win32 +calls. + +On other platforms, calling ``init()`` has no effect (unless you request other +optional functionality; see "Init Keyword Args", below). By design, this permits +applications to call ``init()`` unconditionally on all platforms, after which +ANSI output should just work. + +To stop using Colorama before your program exits, simply call ``deinit()``. +This will restore ``stdout`` and ``stderr`` to their original values, so that +Colorama is disabled. To resume using Colorama again, call ``reinit()``; it is +cheaper than calling ``init()`` again (but does the same thing). + + +Colored Output +.............. + +Cross-platform printing of colored text can then be done using Colorama's +constant shorthand for ANSI escape sequences: + +.. code-block:: python + + from colorama import Fore, Back, Style + print(Fore.RED + 'some red text') + print(Back.GREEN + 'and with a green background') + print(Style.DIM + 'and in dim text') + print(Style.RESET_ALL) + print('back to normal now') + +...or simply by manually printing ANSI sequences from your own code: + +.. code-block:: python + + print('\033[31m' + 'some red text') + print('\033[39m') # and reset to default color + +...or, Colorama can be used in conjunction with existing ANSI libraries +such as the venerable `Termcolor `_ +or the fabulous `Blessings `_. +This is highly recommended for anything more than trivial coloring: + +.. code-block:: python + + from colorama import init + from termcolor import colored + + # use Colorama to make Termcolor work on Windows too + init() + + # then use Termcolor for all colored text output + print(colored('Hello, World!', 'green', 'on_red')) + +Available formatting constants are:: + + Fore: BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE, RESET. + Back: BLACK, RED, GREEN, YELLOW, BLUE, MAGENTA, CYAN, WHITE, RESET. + Style: DIM, NORMAL, BRIGHT, RESET_ALL + +``Style.RESET_ALL`` resets foreground, background, and brightness. Colorama will +perform this reset automatically on program exit. + + +Cursor Positioning +.................. + +ANSI codes to reposition the cursor are supported. See ``demos/demo06.py`` for +an example of how to generate them. + + +Init Keyword Args +................. + +``init()`` accepts some ``**kwargs`` to override default behaviour. + +init(autoreset=False): + If you find yourself repeatedly sending reset sequences to turn off color + changes at the end of every print, then ``init(autoreset=True)`` will + automate that: + + .. code-block:: python + + from colorama import init + init(autoreset=True) + print(Fore.RED + 'some red text') + print('automatically back to default color again') + +init(strip=None): + Pass ``True`` or ``False`` to override whether ANSI codes should be + stripped from the output. The default behaviour is to strip if on Windows + or if output is redirected (not a tty). + +init(convert=None): + Pass ``True`` or ``False`` to override whether to convert ANSI codes in the + output into win32 calls. The default behaviour is to convert if on Windows + and output is to a tty (terminal). + +init(wrap=True): + On Windows, Colorama works by replacing ``sys.stdout`` and ``sys.stderr`` + with proxy objects, which override the ``.write()`` method to do their work. + If this wrapping causes you problems, then this can be disabled by passing + ``init(wrap=False)``. The default behaviour is to wrap if ``autoreset`` or + ``strip`` or ``convert`` are True. + + When wrapping is disabled, colored printing on non-Windows platforms will + continue to work as normal. To do cross-platform colored output, you can + use Colorama's ``AnsiToWin32`` proxy directly: + + .. code-block:: python + + import sys + from colorama import init, AnsiToWin32 + init(wrap=False) + stream = AnsiToWin32(sys.stderr).stream + + # Python 2 + print >>stream, Fore.BLUE + 'blue text on stderr' + + # Python 3 + print(Fore.BLUE + 'blue text on stderr', file=stream) + + +Recognised ANSI Sequences +......................... + +ANSI sequences generally take the form:: + + ESC [ ; ... + +Where ```` is an integer, and ```` is a single letter. Zero or +more params are passed to a ````. If no params are passed, it is +generally synonymous with passing a single zero. No spaces exist in the +sequence; they have been inserted here simply to read more easily. + +The only ANSI sequences that Colorama converts into win32 calls are:: + + ESC [ 0 m # reset all (colors and brightness) + ESC [ 1 m # bright + ESC [ 2 m # dim (looks same as normal brightness) + ESC [ 22 m # normal brightness + + # FOREGROUND: + ESC [ 30 m # black + ESC [ 31 m # red + ESC [ 32 m # green + ESC [ 33 m # yellow + ESC [ 34 m # blue + ESC [ 35 m # magenta + ESC [ 36 m # cyan + ESC [ 37 m # white + ESC [ 39 m # reset + + # BACKGROUND + ESC [ 40 m # black + ESC [ 41 m # red + ESC [ 42 m # green + ESC [ 43 m # yellow + ESC [ 44 m # blue + ESC [ 45 m # magenta + ESC [ 46 m # cyan + ESC [ 47 m # white + ESC [ 49 m # reset + + # cursor positioning + ESC [ y;x H # position cursor at x across, y down + ESC [ y;x f # position cursor at x across, y down + ESC [ n A # move cursor n lines up + ESC [ n B # move cursor n lines down + ESC [ n C # move cursor n characters forward + ESC [ n D # move cursor n characters backward + + # clear the screen + ESC [ mode J # clear the screen + + # clear the line + ESC [ mode K # clear the line + +Multiple numeric params to the ``'m'`` command can be combined into a single +sequence:: + + ESC [ 36 ; 45 ; 1 m # bright cyan text on magenta background + +All other ANSI sequences of the form ``ESC [ ; ... `` +are silently stripped from the output on Windows. + +Any other form of ANSI sequence, such as single-character codes or alternative +initial characters, are not recognised or stripped. It would be cool to add +them though. Let me know if it would be useful for you, via the Issues on +GitHub. + + +Status & Known Problems +----------------------- + +I've personally only tested it on Windows XP (CMD, Console2), Ubuntu +(gnome-terminal, xterm), and OS X. + +Some presumably valid ANSI sequences aren't recognised (see details below), +but to my knowledge nobody has yet complained about this. Puzzling. + +See outstanding issues and wish-list: +https://github.com/tartley/colorama/issues + +If anything doesn't work for you, or doesn't do what you expected or hoped for, +I'd love to hear about it on that issues list, would be delighted by patches, +and would be happy to grant commit access to anyone who submits a working patch +or two. + + +License +------- + +Copyright Jonathan Hartley & Arnon Yaari, 2013-2020. BSD 3-Clause license; see +LICENSE file. + + +Development +----------- + +Help and fixes welcome! + +Tested on CPython 2.7, 3.5, 3.6, 3.7 and 3.8. + +No requirements other than the standard library. +Development requirements are captured in requirements-dev.txt. + +To create and populate a virtual environment:: + + ./bootstrap.ps1 # Windows + make bootstrap # Linux + +To run tests:: + + ./test.ps1 # Windows + make test # Linux + +If you use nose to run the tests, you must pass the ``-s`` flag; otherwise, +``nosetests`` applies its own proxy to ``stdout``, which confuses the unit +tests. + + +Professional support +-------------------- + +.. |tideliftlogo| image:: https://cdn2.hubspot.net/hubfs/4008838/website/logos/logos_for_download/Tidelift_primary-shorthand-logo.png + :alt: Tidelift + :target: https://tidelift.com/subscription/pkg/pypi-colorama?utm_source=pypi-colorama&utm_medium=referral&utm_campaign=readme + +.. list-table:: + :widths: 10 100 + + * - |tideliftlogo| + - Professional support for colorama is available as part of the + `Tidelift Subscription`_. + Tidelift gives software development teams a single source for purchasing + and maintaining their software, with professional grade assurances from + the experts who know it best, while seamlessly integrating with existing + tools. + +.. _Tidelift Subscription: https://tidelift.com/subscription/pkg/pypi-colorama?utm_source=pypi-colorama&utm_medium=referral&utm_campaign=readme + + +Thanks +------ + +* Marc Schlaich (schlamar) for a ``setup.py`` fix for Python2.5. +* Marc Abramowitz, reported & fixed a crash on exit with closed ``stdout``, + providing a solution to issue #7's setuptools/distutils debate, + and other fixes. +* User 'eryksun', for guidance on correctly instantiating ``ctypes.windll``. +* Matthew McCormick for politely pointing out a longstanding crash on non-Win. +* Ben Hoyt, for a magnificent fix under 64-bit Windows. +* Jesse at Empty Square for submitting a fix for examples in the README. +* User 'jamessp', an observant documentation fix for cursor positioning. +* User 'vaal1239', Dave Mckee & Lackner Kristof for a tiny but much-needed Win7 + fix. +* Julien Stuyck, for wisely suggesting Python3 compatible updates to README. +* Daniel Griffith for multiple fabulous patches. +* Oscar Lesta for a valuable fix to stop ANSI chars being sent to non-tty + output. +* Roger Binns, for many suggestions, valuable feedback, & bug reports. +* Tim Golden for thought and much appreciated feedback on the initial idea. +* User 'Zearin' for updates to the README file. +* John Szakmeister for adding support for light colors +* Charles Merriam for adding documentation to demos +* Jurko for a fix on 64-bit Windows CPython2.5 w/o ctypes +* Florian Bruhin for a fix when stdout or stderr are None +* Thomas Weininger for fixing ValueError on Windows +* Remi Rampin for better Github integration and fixes to the README file +* Simeon Visser for closing a file handle using 'with' and updating classifiers + to include Python 3.3 and 3.4 +* Andy Neff for fixing RESET of LIGHT_EX colors. +* Jonathan Hartley for the initial idea and implementation. + + + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/RECORD b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/RECORD new file mode 100644 index 00000000..3516c658 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/RECORD @@ -0,0 +1,18 @@ +colorama-0.4.4.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4 +colorama-0.4.4.dist-info/LICENSE.txt,sha256=ysNcAmhuXQSlpxQL-zs25zrtSWZW6JEQLkKIhteTAxg,1491 +colorama-0.4.4.dist-info/METADATA,sha256=JmU7ePpEh1xcqZV0JKcrrlU7cp5o4InDlHJXbo_FTQw,14551 +colorama-0.4.4.dist-info/RECORD,, +colorama-0.4.4.dist-info/WHEEL,sha256=gxPaqcqKPLUXaSAKwmfHO7_iAOlVvmp33DewnUluBB8,116 +colorama-0.4.4.dist-info/top_level.txt,sha256=_Kx6-Cni2BT1PEATPhrSRxo0d7kSgfBbHf5o7IF1ABw,9 +colorama/__init__.py,sha256=pCdErryzLSzDW5P-rRPBlPLqbBtIRNJB6cMgoeJns5k,239 +colorama/__pycache__/__init__.cpython-39.pyc,, +colorama/__pycache__/ansi.cpython-39.pyc,, +colorama/__pycache__/ansitowin32.cpython-39.pyc,, +colorama/__pycache__/initialise.cpython-39.pyc,, +colorama/__pycache__/win32.cpython-39.pyc,, +colorama/__pycache__/winterm.cpython-39.pyc,, +colorama/ansi.py,sha256=Top4EeEuaQdBWdteKMEcGOTeKeF19Q-Wo_6_Cj5kOzQ,2522 +colorama/ansitowin32.py,sha256=yV7CEmCb19MjnJKODZEEvMH_fnbJhwnpzo4sxZuGXmA,10517 +colorama/initialise.py,sha256=PprovDNxMTrvoNHFcL2NZjpH2XzDc8BLxLxiErfUl4k,1915 +colorama/win32.py,sha256=bJ8Il9jwaBN5BJ8bmN6FoYZ1QYuMKv2j8fGrXh7TJjw,5404 +colorama/winterm.py,sha256=2y_2b7Zsv34feAsP67mLOVc-Bgq51mdYGo571VprlrM,6438 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/WHEEL b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/WHEEL new file mode 100644 index 00000000..6d38aa06 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/WHEEL @@ -0,0 +1,6 @@ +Wheel-Version: 1.0 +Generator: bdist_wheel (0.35.1) +Root-Is-Purelib: true +Tag: py2-none-any +Tag: py3-none-any + diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/top_level.txt b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/top_level.txt new file mode 100644 index 00000000..3fcfb51b --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama-0.4.4.dist-info/top_level.txt @@ -0,0 +1 @@ +colorama diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__init__.py new file mode 100644 index 00000000..b149ed79 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/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.4' diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..2e976626e77b9a4f3115e2da5f1cca49beb308cc GIT binary patch literal 400 zcmYjNJx{|h5RDTjO_N5f{RnQ)va8$lGn@4ns@6- tbzVP+m)Z;P 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 Wq1;c>|8#sxVbFK;vQ;Tn?Ee7)bf*^p literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansi.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansi.py new file mode 100644 index 00000000..11ec695f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/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 = '\a' + + +def code_to_chars(code): + return CSI + str(code) + 'm' + +def set_title(title): + return OSC + '2;' + title + BEL + +def clear_screen(mode=2): + return CSI + str(mode) + 'J' + +def clear_line(mode=2): + return CSI + str(mode) + 'K' + + +class AnsiCodes(object): + def __init__(self): + # the subclasses declare class attributes which are numbers. + # Upon instantiation we define instance attributes, which are the same + # as the class attributes but wrapped with the ANSI escape sequence + for name in dir(self): + if not name.startswith('_'): + value = getattr(self, name) + setattr(self, name, code_to_chars(value)) + + +class AnsiCursor(object): + def UP(self, n=1): + return CSI + str(n) + 'A' + def DOWN(self, n=1): + return CSI + str(n) + 'B' + def FORWARD(self, n=1): + return CSI + str(n) + 'C' + def BACK(self, n=1): + return CSI + str(n) + 'D' + def POS(self, x=1, y=1): + return CSI + str(y) + ';' + str(x) + 'H' + + +class AnsiFore(AnsiCodes): + BLACK = 30 + RED = 31 + GREEN = 32 + YELLOW = 33 + BLUE = 34 + MAGENTA = 35 + CYAN = 36 + WHITE = 37 + RESET = 39 + + # These are fairly well supported, but not part of the standard. + LIGHTBLACK_EX = 90 + LIGHTRED_EX = 91 + LIGHTGREEN_EX = 92 + LIGHTYELLOW_EX = 93 + LIGHTBLUE_EX = 94 + LIGHTMAGENTA_EX = 95 + LIGHTCYAN_EX = 96 + LIGHTWHITE_EX = 97 + + +class AnsiBack(AnsiCodes): + BLACK = 40 + RED = 41 + GREEN = 42 + YELLOW = 43 + BLUE = 44 + MAGENTA = 45 + CYAN = 46 + WHITE = 47 + RESET = 49 + + # These are fairly well supported, but not part of the standard. + LIGHTBLACK_EX = 100 + LIGHTRED_EX = 101 + LIGHTGREEN_EX = 102 + LIGHTYELLOW_EX = 103 + LIGHTBLUE_EX = 104 + LIGHTMAGENTA_EX = 105 + LIGHTCYAN_EX = 106 + LIGHTWHITE_EX = 107 + + +class AnsiStyle(AnsiCodes): + BRIGHT = 1 + DIM = 2 + NORMAL = 22 + RESET_ALL = 0 + +Fore = AnsiFore() +Back = AnsiBack() +Style = AnsiStyle() +Cursor = AnsiCursor() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansitowin32.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansitowin32.py new file mode 100644 index 00000000..6039a054 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/ansitowin32.py @@ -0,0 +1,258 @@ +# Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file. +import re +import sys +import os + +from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style, BEL +from .winterm import 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\\]([^\a]*)(\a)\002?') # Operating System Command + + def __init__(self, wrapped, convert=None, strip=None, autoreset=False): + # The wrapped stream (normally sys.stdout or sys.stderr) + self.wrapped = wrapped + + # should we reset colors to defaults after every .write() + self.autoreset = autoreset + + # create the proxy wrapping our output stream + self.stream = StreamWrapper(wrapped, self) + + on_windows = os.name == 'nt' + # We test if the WinAPI works, because even if we are on Windows + # we may be using a terminal that doesn't support the WinAPI + # (e.g. Cygwin Terminal). In this case it's up to the terminal + # to support the ANSI codes. + conversion_supported = on_windows and winapi_test() + + # 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 == BEL: + if paramstring.count(";") == 1: + params = paramstring.split(";") + # 0 - change title and icon (we will only change title) + # 1 - change icon (we don't support this) + # 2 - change title + if params[0] in '02': + winterm.set_title(params[1]) + return text diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/initialise.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/initialise.py new file mode 100644 index 00000000..430d0668 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/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/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/win32.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/win32.py new file mode 100644 index 00000000..c2d83603 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/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/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/winterm.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/colorama/winterm.py new file mode 100644 index 00000000..0fdb4ec4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/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/Rahul/task4/pyvenv3.9/Lib/site-packages/distutils-precedence.pth b/Rahul/task4/pyvenv3.9/Lib/site-packages/distutils-precedence.pth new file mode 100644 index 00000000..6de4198f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/distutils-precedence.pth @@ -0,0 +1 @@ +import os; var = 'SETUPTOOLS_USE_DISTUTILS'; enabled = os.environ.get(var, 'stdlib') == 'local'; enabled and __import__('_distutils_hack').add_shim(); diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__init__.py new file mode 100644 index 00000000..43b54683 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__init__.py @@ -0,0 +1,46 @@ +from markupsafe import escape +from markupsafe import Markup +from werkzeug.exceptions import abort as abort +from werkzeug.utils import redirect as redirect + +from . import json as json +from .app import Flask as Flask +from .app import Request as Request +from .app import Response as Response +from .blueprints import Blueprint as Blueprint +from .config import Config as Config +from .ctx import after_this_request as after_this_request +from .ctx import copy_current_request_context as copy_current_request_context +from .ctx import has_app_context as has_app_context +from .ctx import has_request_context as has_request_context +from .globals import _app_ctx_stack as _app_ctx_stack +from .globals import _request_ctx_stack as _request_ctx_stack +from .globals import current_app as current_app +from .globals import g as g +from .globals import request as request +from .globals import session as session +from .helpers import flash as flash +from .helpers import get_flashed_messages as get_flashed_messages +from .helpers import get_template_attribute as get_template_attribute +from .helpers import make_response as make_response +from .helpers import safe_join as safe_join +from .helpers import send_file as send_file +from .helpers import send_from_directory as send_from_directory +from .helpers import stream_with_context as stream_with_context +from .helpers import url_for as url_for +from .json import jsonify as jsonify +from .signals import appcontext_popped as appcontext_popped +from .signals import appcontext_pushed as appcontext_pushed +from .signals import appcontext_tearing_down as appcontext_tearing_down +from .signals import before_render_template as before_render_template +from .signals import got_request_exception as got_request_exception +from .signals import message_flashed as message_flashed +from .signals import request_finished as request_finished +from .signals import request_started as request_started +from .signals import request_tearing_down as request_tearing_down +from .signals import signals_available as signals_available +from .signals import template_rendered as template_rendered +from .templating import render_template as render_template +from .templating import render_template_string as render_template_string + +__version__ = "2.0.2" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__main__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__main__.py new file mode 100644 index 00000000..4e28416e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__main__.py @@ -0,0 +1,3 @@ +from .cli import main + +main() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..c3af6f2352e3c37dfd7455fb59446b4850c2fae1 GIT binary patch literal 1855 zcmbu9$!;Sz5QeqbYFVqbSl;(lUSyA*nMr~m2r@uUNe&Yrhk^m3rKY4FvzL%;Z*P=m z$s72Z)4YODsVYgf;A|zzW-Ez5*!q4;bqx(-jmHL+k)1M3ue!`zAA$ch; ztx`c6(rMxhat1QYS(OcDV1{`{%?3HhA0ZbFl}io5^|%=4-hEW#pl4S5NcnCr;Pu*}>* zUV#gi84Q=La>1NVU(u z(m83TpK{Xl+*lI*=IWayMw)fIk+ukVEj?e$p8c90MbCUOQAiQLDA(K|IG^QTi8LJi zS(-Qs4Xrizvr1&F{g5VdpQ5nu50L6^-%2g)&^JQAT)5VY;s?=7w3eZr_@WnuR^HR~ z)uC&I8^=>tgRJoiQ+8z(X77cuZjbV-zeY{D#mUWZRSZf~Zq92$j*-UrqmA})qeGl- z4x|-4ke&!|-W^DTev5o7gIKv%3fEfgcN0rBC_ao$33bKfY;o z;$dgBrE0h;}1etVb5<}U%6c_QEigTI5%Da7k!&&>y3pcfj0O!d)c|@T>jqv z7778Mb83dB7o^UjK;us8n@5=pIxm|udWL2yFEfetmC>_kKBcrnb6G5<#y4+D&ympE z7z*9V**Cg~##0X4g6ChCXprsMdtIjB3Q3h@o+g}uin_RKT_dYb(jaM)EReKNz!^#v zOKtQbSxY3#Br7DVBx@w=BpW1~BwHxpjO(hm$=V^=CD|j{CpjQFBsn5!lN^(rpg>{V z0xYLKCHD;FsVKxP=7Wbph`&?%iY7>&KYHI^4^%Qx@;ZLFmErAG=ez4){qD8#tvrkI u`J_kanx3hfb0P4kSRp#`!&Cl;Ao3C=f25a=`4gp-=5J>FKN|gC&HM)=UHRMq literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__main__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/__main__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..05d1f31d03eb4beb8e32194b379ae02baf100b8a GIT binary patch literal 186 zcmYe~<>g`kf?vO?66JvOV-N=!FabFZKwK;aBvKes7;_kM8KW2(8B!UW85kK-n1UHJ znO`yjB{dmuvE(LZ=J{zd-C|D8$t(hCUCB_y0;IsiFY^?unDm^|^qka~g37YgyfR}w z%NU=`q?qE&l2qM-#N_P6^wi>*w4B7^Z2kCnkYVxhdIgoYIBatBQ%ZAE?LhVvgUsb& F0suMtE06#H literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/app.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/app.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4e499113b3ab59e0f866e69f1114192159c559a0 GIT binary patch literal 63206 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/config.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/config.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fcc1f52b3a405de2defbd3a626aa2b4a98352e71 GIT binary patch literal 11684 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 WUev$&Vs7zU%O_XQExMrObN>res`cIg literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/debughelpers.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/debughelpers.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5c977fec0f5fcc1b54887c1d5a87a59ddb766a73 GIT binary patch literal 6454 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/helpers.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/helpers.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..feeb75997e0cec1cf26d1c7a66cb0328dd51edc9 GIT binary patch literal 27287 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/sessions.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/sessions.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9de2cc85feebd63d3486eb4ce0c84e30ab636588 GIT binary patch literal 13069 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/signals.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/signals.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..12c6712b5970b4febdcea9d905833ad5d8df867e GIT binary patch literal 2342 zcmZuyUvDEd5cmGcCe5EVX?u4)xCcL=lOkOL0tpF(&>_U3lTc5hNPwwiIcq1~cDtLi zz3nBsCwd=)2Y9?M!3Wt_p7;ut5X?B)Rno(i-Ji#^GoIg!C!*JD6BxI*OYu{SkiT%V zIY369!Zd%vB8l`;!o1}nAV2jl0~UBh1}yxMWFLn_H5SJn!9N+Y@LM7qGI~Q~bmOxC zc1_uWT?=;6&m{9dA}Y8ctf`v6x8%+r9@}xK4XEu<2T;eME}*VMJwQE&b^+}=vyyA(U3#``y_nl1hq!eQOu8FxEM1hLGYr#tZFz1V!+vYj z^uGdeO~1zi*-@ctoJT6WlY%BlTh){iqy{T3gnGIw-;r&Qw^chNtOK(Pvj9T4dr%B&nFB>Isdt5>`<`r;v3T1JQ`(rQpWVUQtktQLMEKN_F;twbV4+ClA-UaxNLF`Z-R5Z1HwC1 zf<>2PiRJtr92)dQya;;E#?u;CDnoc2aBova7uWb-H$gjwq}2nT5bj^VbjIq-IKOWL zjTNcyY@ODpGO`{jB?ak=f)@eS_tpkHGES zFd7`|=@G`^8ouXy{=a_U|Faxy#^bc`?eA;6yxzkF)2R<}8Q`*y%KTWBOm zzmMByoM)MeE$gfSze)t_t~W|@o3kUUE+K58lXStiPTDdtm4U&TFkGuxC09xtKFu}j zZEZJVbV+kP2J?+qH+buo7e?=eN5N6l_d*Xk4xTOt=styqJJOIorIlRXpD3_j2}YH| za!;$5g)(*oWNQnG{Yo%}8Z~DiIjkh`{xsxtB=hTRd2g0mFu(d(y^57`vPK8N_M zdS$`MhW=pVU|u-GTcUhE2VZ;et7V|6kFckM^Wi}m*~J{Zx~#C~x>#IiWrKB3;dRF< zJI|4LyQ&i;gSGft%e8G*a|6t;xM6E<)&gE}!zyn0nj2Pe!z*rB#SMJqVue?KoiXGF ztT}FY%?;b&W?O%Q2)^QmZHXK=tm1~Rx%t29C|h5we#O4TmS8@>67hYn>$kkF7y7&5 M;iIV0_U``u2l*;!MF0Q* literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/templating.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/templating.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..87b92d40e9a0e6f616bb5ccce18b7a04e5282789 GIT binary patch literal 5523 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/typing.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/typing.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7b441906ada58b11d66744b12e7367b49225d2d8 GIT binary patch literal 1747 zcmZuw>uwuG6yDig+iSO3_mXA(p^eL* zhsJ$e>0iXMxW$REC;{@^mY<vS$%(sAygoPz~en)F*l zyEU~ZnaieA!$caeJjrZ91LiO57{R{0JSbrI70iBzSD?-3c=cz8uA+TSkx} zGT9$%3+HruXiqwKjAw!u^=oh&_nk&RL67|lk$;+d{FL6=vUrWxUs=2kcb?yc)wcDM zL%Wi(g(l#&-GJTDlu+aAQAx+{a1zA8xS2`%A zjY2iIAOaZ%n=b=MbalUDtHM#7M_ko{ILahDVKQV<7GU~+KHcO#uJk$zK-O`K+Tei8 z$*(rIx%0}U1@0o&f@*C_8Ov=JaRIW&gkVPk^iH7tswg4LWfW*g(@*Ofeh*jbqTm*` zBD=p?Sm&l722#HaS)GcDFZefyLy->!942Qc5S@J9{rYexJUUFn4DKc@IA%jg4+ny! z$M>?cB#egLtl;QOlL`=glWLhDuEe~~jW zj>sZ*REyK$@0&wDVZ}uKP z+TEgcA48D-2)uim4nuRTbmbJ}@j2wfE@v4_GnofCU`Wl)EALdYBtd={I;g_a2rph0 z*Q2w8Oe*(57-Y)9BITep9&IboF1%0b4mJnh9CXl2a1U7U+@cfvGN zg?^q0pmXDZDWla1JI9k)#KWpmAJ6cNNmZT^aXdWliD4xZbRH@GL~h{l5{dgh2E4f` zlW1#wkb&HX7dfQa%)7b)gIL1DP^Q_{*wQ$5#jR=^EQJ{c+Ux_9JU)$PJ=gj$N(9TG zhmQkZW_vOYAWh>LtLgGI<6$Te)U0ym-xBc=6H~u(kK$O+*0idB=>*EHf|G z7_eNtJ==BknE~!e9LQA+^JBXB2oRzaZ#PwT2FgRUSscW|(CQNP%p=nLQ{J~@E`O)r zUb=_EbBd&@f5#;@aY>yt|FPe=MHlTgT({o11s%~jbz=XGF|TP?NE59VSthHfX?=m* JbUfnO{{j%E*(v}4 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/views.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/views.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f6ce998d7b10b6b0579fde3564f40cd182c789ca GIT binary patch literal 4954 zcma)ATW=f372eqkNl}#SI7ws2X*zK)GSh@f+n`7V#jxQ^k~UEa$4ODf#&WeY6jxsD z(zCNtsM19dxv=w)zV)dtU>5}nKlBgnYoGEL{LuD0v#TW~J8c%2;m*w2GiT;}^PMvc zmX_KUp2v^(g0&Yc>tEEEe;R0%s+V=V$ zvt(n_5{9^5d6dklXvL)MM=_|LtDA>nV zclm3~X{~?FPYJ2$HfMo5H_}>Q@Ec-ayR&gYgrd!EmaceXh-thV8V6E^Gxy`jPqfh zgl3sN&M)vR-w5L%%lIhBNG#eO$8sCn*yeavx1}Df4n&lh)%(?+4*2dU3P(K3co@X7 z6nr<*Bd$l)6oJ~zNk_(qD&01kXzY`#A8?iCI!ZQqHp#Tyh6(Qv`D&oGS{=|_smKPT zcC6B!NI)@tR}C0FBIQY{VJ%h$b2lU(!+H`-jcjG{?}u2_&E6GL2SWI{ihY&Ga$vNS z8oB&@97kcKO2a}9`OytK zo5^_i8c%|4c|;j~p$shf@XUKMj#K_S61)A%nVDK3x;MXwvny|mNc4?05{y4_OUZ$>iVlQah`5>1;XWSFWzOCIoXoNsOh8*$}DBNfGQ zz1b2@mWsm#dK8oZ*(G(g-w&W=fT1L`3VwED!gm!`Kwc-wYPCCb3VAv-TU&XpGJ4SE zsWL`}L1KVQ-&H87>`fJbLb!=GaxI^9-^VhnXfUo~yU^RcLs%-e7}!qirLg6E$Z=79}Bln}S4k(>$&Rsk4Ghd2E72m;;J#qiRzo zlHer{lg}$=aJ^_&hp9MKop?XUb-E4a3jG5%ZqEz>nKw%Ogv9y>54}^lh>}sj($>E9 z1v62?-uvgr6~{?pxso^19jO!u2IhlpDms{_KU$Zukw6iIIuGK*E8t-&BzE=MoPr~K z2x_cV&^8^WMYD5;5l{2xSmB?zCI4Zo57~ct{WbFgD4>DjVHzNqs(-Uw#-Ild3(>(ap@hE z=(>eVG*h&VhkdLfD>~)-&0T7#6ZkwdN=OkN4+UY!I);+%pwiYBGsPC{zH`^Q%kJ7k zL`dP>>3nHVtu04gnX-Gf@8aFVuSb2CtQ(!%?$o_!@3SxMTW?P-j5KPwCR)uo`4-wO zv={J;f|%$Ae*i8nrU~4QXhcpZVHzcHHpu0vo;7ELs0Yyn2Vc~_siWMJQ7kb5H;xf& z2@nUc&p@j+E2idj*V={p*9l(CwSuQlzL@lu4E=>1UH9RLEMbuA^SUkNPfE&!Kwcs8jU*BC5ir@6Dl7-=WS| zP+djI$Rdj!XL~Q2gHc7N-dda@>&edb=(}#aV7hQFBojrTSI?j-TE0&w#`lZ1?{B99 z2i*77%QV#VeUXM}(a})HQFXn-3FAziq>h6}=6&R%ZXHd_ByG#;WHddT7QWE|B&{!Q8UU2AAAB6nJS_b$NI_lOUQ z7!^gR2W-lw_SAVu_aruTc9@E_y>Ef?Y*61zw>|AlJ%KC5zN5}e z-3RW}+wvYVX5BiY8%Cm`L4ec7zO61{yftk+Sa@g|3A9x_1)chyu&{J{-S`)H^-M-X zAdQkp1Efxdi%=7{A1(bRag^;M1sd@z7}2ZIW>5Yf1@A?R$B zNe)Fhx(tjER*?P=2DsNiy0Rwg@h21Pi)l_V@4~O&KRa9Ik&KtFLYUXwevS-L_^ECJ z080i&>5=40SgOU9=FRHHLXz~5GPis*Q`Cdx zc>xxdM2~+;8hS$aQAJw8d~v#gfL^YTzBBQwSiqkbdq^duR&P@$#h=2(m(q}gQT#L; fiq={g^Uu+p#6+`}-2t6-9Gf-%<9f?Cj-UQ7-f2*2 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/wrappers.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/__pycache__/wrappers.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6042ec69df979c2643fb914e43bb7e9a67ab2907 GIT binary patch literal 4995 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/app.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/app.py new file mode 100644 index 00000000..23b99e2c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/app.py @@ -0,0 +1,2091 @@ +import functools +import inspect +import logging +import os +import sys +import typing as t +import weakref +from datetime import timedelta +from itertools import chain +from threading import Lock +from types import TracebackType + +from werkzeug.datastructures import Headers +from werkzeug.datastructures import ImmutableDict +from werkzeug.exceptions import BadRequest +from werkzeug.exceptions import BadRequestKeyError +from werkzeug.exceptions import HTTPException +from werkzeug.exceptions import InternalServerError +from werkzeug.local import ContextVar +from werkzeug.routing import BuildError +from werkzeug.routing import Map +from werkzeug.routing import MapAdapter +from werkzeug.routing import RequestRedirect +from werkzeug.routing import RoutingException +from werkzeug.routing import Rule +from werkzeug.wrappers import Response as BaseResponse + +from . import cli +from . import json +from .config import Config +from .config import ConfigAttribute +from .ctx import _AppCtxGlobals +from .ctx import AppContext +from .ctx import RequestContext +from .globals import _request_ctx_stack +from .globals import g +from .globals import request +from .globals import session +from .helpers import _split_blueprint_path +from .helpers import get_debug_flag +from .helpers import get_env +from .helpers import get_flashed_messages +from .helpers import get_load_dotenv +from .helpers import locked_cached_property +from .helpers import url_for +from .json import jsonify +from .logging import create_logger +from .scaffold import _endpoint_from_view_func +from .scaffold import _sentinel +from .scaffold import find_package +from .scaffold import Scaffold +from .scaffold import setupmethod +from .sessions import SecureCookieSessionInterface +from .signals import appcontext_tearing_down +from .signals import got_request_exception +from .signals import request_finished +from .signals import request_started +from .signals import request_tearing_down +from .templating import DispatchingJinjaLoader +from .templating import Environment +from .typing import BeforeFirstRequestCallable +from .typing import ResponseReturnValue +from .typing import TeardownCallable +from .typing import TemplateFilterCallable +from .typing import TemplateGlobalCallable +from .typing import TemplateTestCallable +from .wrappers import Request +from .wrappers import Response + +if t.TYPE_CHECKING: + import typing_extensions as te + from .blueprints import Blueprint + from .testing import FlaskClient + from .testing import FlaskCliRunner + from .typing import ErrorHandlerCallable + +if sys.version_info >= (3, 8): + iscoroutinefunction = inspect.iscoroutinefunction +else: + + def iscoroutinefunction(func: t.Any) -> bool: + while inspect.ismethod(func): + func = func.__func__ + + while isinstance(func, functools.partial): + func = func.func + + return inspect.iscoroutinefunction(func) + + +def _make_timedelta(value: t.Optional[timedelta]) -> t.Optional[timedelta]: + if value is None or isinstance(value, timedelta): + return value + + return timedelta(seconds=value) + + +class Flask(Scaffold): + """The flask object implements a WSGI application and acts as the central + object. It is passed the name of the module or package of the + application. Once it is created it will act as a central registry for + the view functions, the URL rules, template configuration and much more. + + The name of the package is used to resolve resources from inside the + package or the folder the module is contained in depending on if the + package parameter resolves to an actual python package (a folder with + an :file:`__init__.py` file inside) or a standard module (just a ``.py`` file). + + For more information about resource loading, see :func:`open_resource`. + + Usually you create a :class:`Flask` instance in your main module or + in the :file:`__init__.py` file of your package like this:: + + from flask import Flask + app = Flask(__name__) + + .. admonition:: About the First Parameter + + The idea of the first parameter is to give Flask an idea of what + belongs to your application. This name is used to find resources + on the filesystem, can be used by extensions to improve debugging + information and a lot more. + + So it's important what you provide there. If you are using a single + module, `__name__` is always the correct value. If you however are + using a package, it's usually recommended to hardcode the name of + your package there. + + For example if your application is defined in :file:`yourapplication/app.py` + you should create it with one of the two versions below:: + + app = Flask('yourapplication') + app = Flask(__name__.split('.')[0]) + + Why is that? The application will work even with `__name__`, thanks + to how resources are looked up. However it will make debugging more + painful. Certain extensions can make assumptions based on the + import name of your application. For example the Flask-SQLAlchemy + extension will look for the code in your application that triggered + an SQL query in debug mode. If the import name is not properly set + up, that debugging information is lost. (For example it would only + pick up SQL queries in `yourapplication.app` and not + `yourapplication.views.frontend`) + + .. versionadded:: 0.7 + The `static_url_path`, `static_folder`, and `template_folder` + parameters were added. + + .. versionadded:: 0.8 + The `instance_path` and `instance_relative_config` parameters were + added. + + .. versionadded:: 0.11 + The `root_path` parameter was added. + + .. versionadded:: 1.0 + The ``host_matching`` and ``static_host`` parameters were added. + + .. versionadded:: 1.0 + The ``subdomain_matching`` parameter was added. Subdomain + matching needs to be enabled manually now. Setting + :data:`SERVER_NAME` does not implicitly enable it. + + :param import_name: the name of the application package + :param static_url_path: can be used to specify a different path for the + static files on the web. Defaults to the name + of the `static_folder` folder. + :param static_folder: The folder with static files that is served at + ``static_url_path``. Relative to the application ``root_path`` + or an absolute path. Defaults to ``'static'``. + :param static_host: the host to use when adding the static route. + Defaults to None. Required when using ``host_matching=True`` + with a ``static_folder`` configured. + :param host_matching: set ``url_map.host_matching`` attribute. + Defaults to False. + :param subdomain_matching: consider the subdomain relative to + :data:`SERVER_NAME` when matching routes. Defaults to False. + :param template_folder: the folder that contains the templates that should + be used by the application. Defaults to + ``'templates'`` folder in the root path of the + application. + :param instance_path: An alternative instance path for the application. + By default the folder ``'instance'`` next to the + package or module is assumed to be the instance + path. + :param instance_relative_config: if set to ``True`` relative filenames + for loading the config are assumed to + be relative to the instance path instead + of the application root. + :param root_path: The path to the root of the application files. + This should only be set manually when it can't be detected + automatically, such as for namespace packages. + """ + + #: The class that is used for request objects. See :class:`~flask.Request` + #: for more information. + request_class = Request + + #: The class that is used for response objects. See + #: :class:`~flask.Response` for more information. + response_class = Response + + #: The class that is used for the Jinja environment. + #: + #: .. versionadded:: 0.11 + jinja_environment = Environment + + #: The class that is used for the :data:`~flask.g` instance. + #: + #: Example use cases for a custom class: + #: + #: 1. Store arbitrary attributes on flask.g. + #: 2. Add a property for lazy per-request database connectors. + #: 3. Return None instead of AttributeError on unexpected attributes. + #: 4. Raise exception if an unexpected attr is set, a "controlled" flask.g. + #: + #: In Flask 0.9 this property was called `request_globals_class` but it + #: was changed in 0.10 to :attr:`app_ctx_globals_class` because the + #: flask.g object is now application context scoped. + #: + #: .. versionadded:: 0.10 + app_ctx_globals_class = _AppCtxGlobals + + #: The class that is used for the ``config`` attribute of this app. + #: Defaults to :class:`~flask.Config`. + #: + #: Example use cases for a custom class: + #: + #: 1. Default values for certain config options. + #: 2. Access to config values through attributes in addition to keys. + #: + #: .. versionadded:: 0.11 + config_class = Config + + #: The testing flag. Set this to ``True`` to enable the test mode of + #: Flask extensions (and in the future probably also Flask itself). + #: For example this might activate test helpers that have an + #: additional runtime cost which should not be enabled by default. + #: + #: If this is enabled and PROPAGATE_EXCEPTIONS is not changed from the + #: default it's implicitly enabled. + #: + #: This attribute can also be configured from the config with the + #: ``TESTING`` configuration key. Defaults to ``False``. + testing = ConfigAttribute("TESTING") + + #: If a secret key is set, cryptographic components can use this to + #: sign cookies and other things. Set this to a complex random value + #: when you want to use the secure cookie for instance. + #: + #: This attribute can also be configured from the config with the + #: :data:`SECRET_KEY` configuration key. Defaults to ``None``. + secret_key = ConfigAttribute("SECRET_KEY") + + #: The secure cookie uses this for the name of the session cookie. + #: + #: This attribute can also be configured from the config with the + #: ``SESSION_COOKIE_NAME`` configuration key. Defaults to ``'session'`` + session_cookie_name = ConfigAttribute("SESSION_COOKIE_NAME") + + #: A :class:`~datetime.timedelta` which is used to set the expiration + #: date of a permanent session. The default is 31 days which makes a + #: permanent session survive for roughly one month. + #: + #: This attribute can also be configured from the config with the + #: ``PERMANENT_SESSION_LIFETIME`` configuration key. Defaults to + #: ``timedelta(days=31)`` + permanent_session_lifetime = ConfigAttribute( + "PERMANENT_SESSION_LIFETIME", get_converter=_make_timedelta + ) + + #: A :class:`~datetime.timedelta` or number of seconds which is used + #: as the default ``max_age`` for :func:`send_file`. The default is + #: ``None``, which tells the browser to use conditional requests + #: instead of a timed cache. + #: + #: Configured with the :data:`SEND_FILE_MAX_AGE_DEFAULT` + #: configuration key. + #: + #: .. versionchanged:: 2.0 + #: Defaults to ``None`` instead of 12 hours. + send_file_max_age_default = ConfigAttribute( + "SEND_FILE_MAX_AGE_DEFAULT", get_converter=_make_timedelta + ) + + #: Enable this if you want to use the X-Sendfile feature. Keep in + #: mind that the server has to support this. This only affects files + #: sent with the :func:`send_file` method. + #: + #: .. versionadded:: 0.2 + #: + #: This attribute can also be configured from the config with the + #: ``USE_X_SENDFILE`` configuration key. Defaults to ``False``. + use_x_sendfile = ConfigAttribute("USE_X_SENDFILE") + + #: The JSON encoder class to use. Defaults to :class:`~flask.json.JSONEncoder`. + #: + #: .. versionadded:: 0.10 + json_encoder = json.JSONEncoder + + #: The JSON decoder class to use. Defaults to :class:`~flask.json.JSONDecoder`. + #: + #: .. versionadded:: 0.10 + json_decoder = json.JSONDecoder + + #: Options that are passed to the Jinja environment in + #: :meth:`create_jinja_environment`. Changing these options after + #: the environment is created (accessing :attr:`jinja_env`) will + #: have no effect. + #: + #: .. versionchanged:: 1.1.0 + #: This is a ``dict`` instead of an ``ImmutableDict`` to allow + #: easier configuration. + #: + jinja_options: dict = {} + + #: Default configuration parameters. + default_config = ImmutableDict( + { + "ENV": None, + "DEBUG": None, + "TESTING": False, + "PROPAGATE_EXCEPTIONS": None, + "PRESERVE_CONTEXT_ON_EXCEPTION": None, + "SECRET_KEY": None, + "PERMANENT_SESSION_LIFETIME": timedelta(days=31), + "USE_X_SENDFILE": False, + "SERVER_NAME": None, + "APPLICATION_ROOT": "/", + "SESSION_COOKIE_NAME": "session", + "SESSION_COOKIE_DOMAIN": None, + "SESSION_COOKIE_PATH": None, + "SESSION_COOKIE_HTTPONLY": True, + "SESSION_COOKIE_SECURE": False, + "SESSION_COOKIE_SAMESITE": None, + "SESSION_REFRESH_EACH_REQUEST": True, + "MAX_CONTENT_LENGTH": None, + "SEND_FILE_MAX_AGE_DEFAULT": None, + "TRAP_BAD_REQUEST_ERRORS": None, + "TRAP_HTTP_EXCEPTIONS": False, + "EXPLAIN_TEMPLATE_LOADING": False, + "PREFERRED_URL_SCHEME": "http", + "JSON_AS_ASCII": True, + "JSON_SORT_KEYS": True, + "JSONIFY_PRETTYPRINT_REGULAR": False, + "JSONIFY_MIMETYPE": "application/json", + "TEMPLATES_AUTO_RELOAD": None, + "MAX_COOKIE_SIZE": 4093, + } + ) + + #: The rule object to use for URL rules created. This is used by + #: :meth:`add_url_rule`. Defaults to :class:`werkzeug.routing.Rule`. + #: + #: .. versionadded:: 0.7 + url_rule_class = Rule + + #: The map object to use for storing the URL rules and routing + #: configuration parameters. Defaults to :class:`werkzeug.routing.Map`. + #: + #: .. versionadded:: 1.1.0 + url_map_class = Map + + #: The :meth:`test_client` method creates an instance of this test + #: client class. Defaults to :class:`~flask.testing.FlaskClient`. + #: + #: .. versionadded:: 0.7 + test_client_class: t.Optional[t.Type["FlaskClient"]] = None + + #: The :class:`~click.testing.CliRunner` subclass, by default + #: :class:`~flask.testing.FlaskCliRunner` that is used by + #: :meth:`test_cli_runner`. Its ``__init__`` method should take a + #: Flask app object as the first argument. + #: + #: .. versionadded:: 1.0 + test_cli_runner_class: t.Optional[t.Type["FlaskCliRunner"]] = None + + #: the session interface to use. By default an instance of + #: :class:`~flask.sessions.SecureCookieSessionInterface` is used here. + #: + #: .. versionadded:: 0.8 + session_interface = SecureCookieSessionInterface() + + def __init__( + self, + import_name: str, + static_url_path: t.Optional[str] = None, + static_folder: t.Optional[t.Union[str, os.PathLike]] = "static", + static_host: t.Optional[str] = None, + host_matching: bool = False, + subdomain_matching: bool = False, + template_folder: t.Optional[str] = "templates", + instance_path: t.Optional[str] = None, + instance_relative_config: bool = False, + root_path: t.Optional[str] = None, + ): + super().__init__( + import_name=import_name, + static_folder=static_folder, + static_url_path=static_url_path, + template_folder=template_folder, + root_path=root_path, + ) + + if instance_path is None: + instance_path = self.auto_find_instance_path() + elif not os.path.isabs(instance_path): + raise ValueError( + "If an instance path is provided it must be absolute." + " A relative path was given instead." + ) + + #: Holds the path to the instance folder. + #: + #: .. versionadded:: 0.8 + self.instance_path = instance_path + + #: The configuration dictionary as :class:`Config`. This behaves + #: exactly like a regular dictionary but supports additional methods + #: to load a config from files. + self.config = self.make_config(instance_relative_config) + + #: A list of functions that are called when :meth:`url_for` raises a + #: :exc:`~werkzeug.routing.BuildError`. Each function registered here + #: is called with `error`, `endpoint` and `values`. If a function + #: returns ``None`` or raises a :exc:`BuildError` the next function is + #: tried. + #: + #: .. versionadded:: 0.9 + self.url_build_error_handlers: t.List[ + t.Callable[[Exception, str, dict], str] + ] = [] + + #: A list of functions that will be called at the beginning of the + #: first request to this instance. To register a function, use the + #: :meth:`before_first_request` decorator. + #: + #: .. versionadded:: 0.8 + self.before_first_request_funcs: t.List[BeforeFirstRequestCallable] = [] + + #: A list of functions that are called when the application context + #: is destroyed. Since the application context is also torn down + #: if the request ends this is the place to store code that disconnects + #: from databases. + #: + #: .. versionadded:: 0.9 + self.teardown_appcontext_funcs: t.List[TeardownCallable] = [] + + #: A list of shell context processor functions that should be run + #: when a shell context is created. + #: + #: .. versionadded:: 0.11 + self.shell_context_processors: t.List[t.Callable[[], t.Dict[str, t.Any]]] = [] + + #: Maps registered blueprint names to blueprint objects. The + #: dict retains the order the blueprints were registered in. + #: Blueprints can be registered multiple times, this dict does + #: not track how often they were attached. + #: + #: .. versionadded:: 0.7 + self.blueprints: t.Dict[str, "Blueprint"] = {} + + #: a place where extensions can store application specific state. For + #: example this is where an extension could store database engines and + #: similar things. + #: + #: The key must match the name of the extension module. For example in + #: case of a "Flask-Foo" extension in `flask_foo`, the key would be + #: ``'foo'``. + #: + #: .. versionadded:: 0.7 + self.extensions: dict = {} + + #: The :class:`~werkzeug.routing.Map` for this instance. You can use + #: this to change the routing converters after the class was created + #: but before any routes are connected. Example:: + #: + #: from werkzeug.routing import BaseConverter + #: + #: class ListConverter(BaseConverter): + #: def to_python(self, value): + #: return value.split(',') + #: def to_url(self, values): + #: return ','.join(super(ListConverter, self).to_url(value) + #: for value in values) + #: + #: app = Flask(__name__) + #: app.url_map.converters['list'] = ListConverter + self.url_map = self.url_map_class() + + self.url_map.host_matching = host_matching + self.subdomain_matching = subdomain_matching + + # tracks internally if the application already handled at least one + # request. + self._got_first_request = False + self._before_request_lock = Lock() + + # Add a static route using the provided static_url_path, static_host, + # and static_folder if there is a configured static_folder. + # Note we do this without checking if static_folder exists. + # For one, it might be created while the server is running (e.g. during + # development). Also, Google App Engine stores static files somewhere + if self.has_static_folder: + assert ( + bool(static_host) == host_matching + ), "Invalid static_host/host_matching combination" + # Use a weakref to avoid creating a reference cycle between the app + # and the view function (see #3761). + self_ref = weakref.ref(self) + self.add_url_rule( + f"{self.static_url_path}/", + endpoint="static", + host=static_host, + view_func=lambda **kw: self_ref().send_static_file(**kw), # type: ignore # noqa: B950 + ) + + # Set the name of the Click group in case someone wants to add + # the app's commands to another CLI tool. + self.cli.name = self.name + + def _is_setup_finished(self) -> bool: + return self.debug and self._got_first_request + + @locked_cached_property + def name(self) -> str: # type: ignore + """The name of the application. This is usually the import name + with the difference that it's guessed from the run file if the + import name is main. This name is used as a display name when + Flask needs the name of the application. It can be set and overridden + to change the value. + + .. versionadded:: 0.8 + """ + if self.import_name == "__main__": + fn = getattr(sys.modules["__main__"], "__file__", None) + if fn is None: + return "__main__" + return os.path.splitext(os.path.basename(fn))[0] + return self.import_name + + @property + def propagate_exceptions(self) -> bool: + """Returns the value of the ``PROPAGATE_EXCEPTIONS`` configuration + value in case it's set, otherwise a sensible default is returned. + + .. versionadded:: 0.7 + """ + rv = self.config["PROPAGATE_EXCEPTIONS"] + if rv is not None: + return rv + return self.testing or self.debug + + @property + def preserve_context_on_exception(self) -> bool: + """Returns the value of the ``PRESERVE_CONTEXT_ON_EXCEPTION`` + configuration value in case it's set, otherwise a sensible default + is returned. + + .. versionadded:: 0.7 + """ + rv = self.config["PRESERVE_CONTEXT_ON_EXCEPTION"] + if rv is not None: + return rv + return self.debug + + @locked_cached_property + def logger(self) -> logging.Logger: + """A standard Python :class:`~logging.Logger` for the app, with + the same name as :attr:`name`. + + In debug mode, the logger's :attr:`~logging.Logger.level` will + be set to :data:`~logging.DEBUG`. + + If there are no handlers configured, a default handler will be + added. See :doc:`/logging` for more information. + + .. versionchanged:: 1.1.0 + The logger takes the same name as :attr:`name` rather than + hard-coding ``"flask.app"``. + + .. versionchanged:: 1.0.0 + Behavior was simplified. The logger is always named + ``"flask.app"``. The level is only set during configuration, + it doesn't check ``app.debug`` each time. Only one format is + used, not different ones depending on ``app.debug``. No + handlers are removed, and a handler is only added if no + handlers are already configured. + + .. versionadded:: 0.3 + """ + return create_logger(self) + + @locked_cached_property + def jinja_env(self) -> Environment: + """The Jinja environment used to load templates. + + The environment is created the first time this property is + accessed. Changing :attr:`jinja_options` after that will have no + effect. + """ + return self.create_jinja_environment() + + @property + def got_first_request(self) -> bool: + """This attribute is set to ``True`` if the application started + handling the first request. + + .. versionadded:: 0.8 + """ + return self._got_first_request + + def make_config(self, instance_relative: bool = False) -> Config: + """Used to create the config attribute by the Flask constructor. + The `instance_relative` parameter is passed in from the constructor + of Flask (there named `instance_relative_config`) and indicates if + the config should be relative to the instance path or the root path + of the application. + + .. versionadded:: 0.8 + """ + root_path = self.root_path + if instance_relative: + root_path = self.instance_path + defaults = dict(self.default_config) + defaults["ENV"] = get_env() + defaults["DEBUG"] = get_debug_flag() + return self.config_class(root_path, defaults) + + def auto_find_instance_path(self) -> str: + """Tries to locate the instance path if it was not provided to the + constructor of the application class. It will basically calculate + the path to a folder named ``instance`` next to your main file or + the package. + + .. versionadded:: 0.8 + """ + prefix, package_path = find_package(self.import_name) + if prefix is None: + return os.path.join(package_path, "instance") + return os.path.join(prefix, "var", f"{self.name}-instance") + + def open_instance_resource(self, resource: str, mode: str = "rb") -> t.IO[t.AnyStr]: + """Opens a resource from the application's instance folder + (:attr:`instance_path`). Otherwise works like + :meth:`open_resource`. Instance resources can also be opened for + writing. + + :param resource: the name of the resource. To access resources within + subfolders use forward slashes as separator. + :param mode: resource file opening mode, default is 'rb'. + """ + return open(os.path.join(self.instance_path, resource), mode) + + @property + def templates_auto_reload(self) -> bool: + """Reload templates when they are changed. Used by + :meth:`create_jinja_environment`. + + This attribute can be configured with :data:`TEMPLATES_AUTO_RELOAD`. If + not set, it will be enabled in debug mode. + + .. versionadded:: 1.0 + This property was added but the underlying config and behavior + already existed. + """ + rv = self.config["TEMPLATES_AUTO_RELOAD"] + return rv if rv is not None else self.debug + + @templates_auto_reload.setter + def templates_auto_reload(self, value: bool) -> None: + self.config["TEMPLATES_AUTO_RELOAD"] = value + + def create_jinja_environment(self) -> Environment: + """Create the Jinja environment based on :attr:`jinja_options` + and the various Jinja-related methods of the app. Changing + :attr:`jinja_options` after this will have no effect. Also adds + Flask-related globals and filters to the environment. + + .. versionchanged:: 0.11 + ``Environment.auto_reload`` set in accordance with + ``TEMPLATES_AUTO_RELOAD`` configuration option. + + .. versionadded:: 0.5 + """ + options = dict(self.jinja_options) + + if "autoescape" not in options: + options["autoescape"] = self.select_jinja_autoescape + + if "auto_reload" not in options: + options["auto_reload"] = self.templates_auto_reload + + rv = self.jinja_environment(self, **options) + rv.globals.update( + url_for=url_for, + get_flashed_messages=get_flashed_messages, + config=self.config, + # request, session and g are normally added with the + # context processor for efficiency reasons but for imported + # templates we also want the proxies in there. + request=request, + session=session, + g=g, + ) + rv.policies["json.dumps_function"] = json.dumps + return rv + + def create_global_jinja_loader(self) -> DispatchingJinjaLoader: + """Creates the loader for the Jinja2 environment. Can be used to + override just the loader and keeping the rest unchanged. It's + discouraged to override this function. Instead one should override + the :meth:`jinja_loader` function instead. + + The global loader dispatches between the loaders of the application + and the individual blueprints. + + .. versionadded:: 0.7 + """ + return DispatchingJinjaLoader(self) + + def select_jinja_autoescape(self, filename: str) -> bool: + """Returns ``True`` if autoescaping should be active for the given + template name. If no template name is given, returns `True`. + + .. versionadded:: 0.5 + """ + if filename is None: + return True + return filename.endswith((".html", ".htm", ".xml", ".xhtml")) + + def update_template_context(self, context: dict) -> None: + """Update the template context with some commonly used variables. + This injects request, session, config and g into the template + context as well as everything template context processors want + to inject. Note that the as of Flask 0.6, the original values + in the context will not be overridden if a context processor + decides to return a value with the same key. + + :param context: the context as a dictionary that is updated in place + to add extra variables. + """ + names: t.Iterable[t.Optional[str]] = (None,) + + # A template may be rendered outside a request context. + if request: + names = chain(names, reversed(request.blueprints)) + + # The values passed to render_template take precedence. Keep a + # copy to re-apply after all context functions. + orig_ctx = context.copy() + + for name in names: + if name in self.template_context_processors: + for func in self.template_context_processors[name]: + context.update(func()) + + context.update(orig_ctx) + + def make_shell_context(self) -> dict: + """Returns the shell context for an interactive shell for this + application. This runs all the registered shell context + processors. + + .. versionadded:: 0.11 + """ + rv = {"app": self, "g": g} + for processor in self.shell_context_processors: + rv.update(processor()) + return rv + + #: What environment the app is running in. Flask and extensions may + #: enable behaviors based on the environment, such as enabling debug + #: mode. This maps to the :data:`ENV` config key. This is set by the + #: :envvar:`FLASK_ENV` environment variable and may not behave as + #: expected if set in code. + #: + #: **Do not enable development when deploying in production.** + #: + #: Default: ``'production'`` + env = ConfigAttribute("ENV") + + @property + def debug(self) -> bool: + """Whether debug mode is enabled. When using ``flask run`` to start + the development server, an interactive debugger will be shown for + unhandled exceptions, and the server will be reloaded when code + changes. This maps to the :data:`DEBUG` config key. This is + enabled when :attr:`env` is ``'development'`` and is overridden + by the ``FLASK_DEBUG`` environment variable. It may not behave as + expected if set in code. + + **Do not enable debug mode when deploying in production.** + + Default: ``True`` if :attr:`env` is ``'development'``, or + ``False`` otherwise. + """ + return self.config["DEBUG"] + + @debug.setter + def debug(self, value: bool) -> None: + self.config["DEBUG"] = value + self.jinja_env.auto_reload = self.templates_auto_reload + + def run( + self, + host: t.Optional[str] = None, + port: t.Optional[int] = None, + debug: t.Optional[bool] = None, + load_dotenv: bool = True, + **options: t.Any, + ) -> None: + """Runs the application on a local development server. + + Do not use ``run()`` in a production setting. It is not intended to + meet security and performance requirements for a production server. + Instead, see :doc:`/deploying/index` for WSGI server recommendations. + + If the :attr:`debug` flag is set the server will automatically reload + for code changes and show a debugger in case an exception happened. + + If you want to run the application in debug mode, but disable the + code execution on the interactive debugger, you can pass + ``use_evalex=False`` as parameter. This will keep the debugger's + traceback screen active, but disable code execution. + + It is not recommended to use this function for development with + automatic reloading as this is badly supported. Instead you should + be using the :command:`flask` command line script's ``run`` support. + + .. admonition:: Keep in Mind + + Flask will suppress any server error with a generic error page + unless it is in debug mode. As such to enable just the + interactive debugger without the code reloading, you have to + invoke :meth:`run` with ``debug=True`` and ``use_reloader=False``. + Setting ``use_debugger`` to ``True`` without being in debug mode + won't catch any exceptions because there won't be any to + catch. + + :param host: the hostname to listen on. Set this to ``'0.0.0.0'`` to + have the server available externally as well. Defaults to + ``'127.0.0.1'`` or the host in the ``SERVER_NAME`` config variable + if present. + :param port: the port of the webserver. Defaults to ``5000`` or the + port defined in the ``SERVER_NAME`` config variable if present. + :param debug: if given, enable or disable debug mode. See + :attr:`debug`. + :param load_dotenv: Load the nearest :file:`.env` and :file:`.flaskenv` + files to set environment variables. Will also change the working + directory to the directory containing the first file found. + :param options: the options to be forwarded to the underlying Werkzeug + server. See :func:`werkzeug.serving.run_simple` for more + information. + + .. versionchanged:: 1.0 + If installed, python-dotenv will be used to load environment + variables from :file:`.env` and :file:`.flaskenv` files. + + If set, the :envvar:`FLASK_ENV` and :envvar:`FLASK_DEBUG` + environment variables will override :attr:`env` and + :attr:`debug`. + + Threaded mode is enabled by default. + + .. versionchanged:: 0.10 + The default port is now picked from the ``SERVER_NAME`` + variable. + """ + # Change this into a no-op if the server is invoked from the + # command line. Have a look at cli.py for more information. + if os.environ.get("FLASK_RUN_FROM_CLI") == "true": + from .debughelpers import explain_ignored_app_run + + explain_ignored_app_run() + return + + if get_load_dotenv(load_dotenv): + cli.load_dotenv() + + # if set, let env vars override previous values + if "FLASK_ENV" in os.environ: + self.env = get_env() + self.debug = get_debug_flag() + elif "FLASK_DEBUG" in os.environ: + self.debug = get_debug_flag() + + # debug passed to method overrides all other sources + if debug is not None: + self.debug = bool(debug) + + server_name = self.config.get("SERVER_NAME") + sn_host = sn_port = None + + if server_name: + sn_host, _, sn_port = server_name.partition(":") + + if not host: + if sn_host: + host = sn_host + else: + host = "127.0.0.1" + + if port or port == 0: + port = int(port) + elif sn_port: + port = int(sn_port) + else: + port = 5000 + + options.setdefault("use_reloader", self.debug) + options.setdefault("use_debugger", self.debug) + options.setdefault("threaded", True) + + cli.show_server_banner(self.env, self.debug, self.name, False) + + from werkzeug.serving import run_simple + + try: + run_simple(t.cast(str, host), port, self, **options) + finally: + # reset the first request information if the development server + # reset normally. This makes it possible to restart the server + # without reloader and that stuff from an interactive shell. + self._got_first_request = False + + def test_client(self, use_cookies: bool = True, **kwargs: t.Any) -> "FlaskClient": + """Creates a test client for this application. For information + about unit testing head over to :doc:`/testing`. + + Note that if you are testing for assertions or exceptions in your + application code, you must set ``app.testing = True`` in order for the + exceptions to propagate to the test client. Otherwise, the exception + will be handled by the application (not visible to the test client) and + the only indication of an AssertionError or other exception will be a + 500 status code response to the test client. See the :attr:`testing` + attribute. For example:: + + app.testing = True + client = app.test_client() + + The test client can be used in a ``with`` block to defer the closing down + of the context until the end of the ``with`` block. This is useful if + you want to access the context locals for testing:: + + with app.test_client() as c: + rv = c.get('/?vodka=42') + assert request.args['vodka'] == '42' + + Additionally, you may pass optional keyword arguments that will then + be passed to the application's :attr:`test_client_class` constructor. + For example:: + + from flask.testing import FlaskClient + + class CustomClient(FlaskClient): + def __init__(self, *args, **kwargs): + self._authentication = kwargs.pop("authentication") + super(CustomClient,self).__init__( *args, **kwargs) + + app.test_client_class = CustomClient + client = app.test_client(authentication='Basic ....') + + See :class:`~flask.testing.FlaskClient` for more information. + + .. versionchanged:: 0.4 + added support for ``with`` block usage for the client. + + .. versionadded:: 0.7 + The `use_cookies` parameter was added as well as the ability + to override the client to be used by setting the + :attr:`test_client_class` attribute. + + .. versionchanged:: 0.11 + Added `**kwargs` to support passing additional keyword arguments to + the constructor of :attr:`test_client_class`. + """ + cls = self.test_client_class + if cls is None: + from .testing import FlaskClient as cls # type: ignore + return cls( # type: ignore + self, self.response_class, use_cookies=use_cookies, **kwargs + ) + + def test_cli_runner(self, **kwargs: t.Any) -> "FlaskCliRunner": + """Create a CLI runner for testing CLI commands. + See :ref:`testing-cli`. + + Returns an instance of :attr:`test_cli_runner_class`, by default + :class:`~flask.testing.FlaskCliRunner`. The Flask app object is + passed as the first argument. + + .. versionadded:: 1.0 + """ + cls = self.test_cli_runner_class + + if cls is None: + from .testing import FlaskCliRunner as cls # type: ignore + + return cls(self, **kwargs) # type: ignore + + @setupmethod + def register_blueprint(self, blueprint: "Blueprint", **options: t.Any) -> None: + """Register a :class:`~flask.Blueprint` on the application. Keyword + arguments passed to this method will override the defaults set on the + blueprint. + + Calls the blueprint's :meth:`~flask.Blueprint.register` method after + recording the blueprint in the application's :attr:`blueprints`. + + :param blueprint: The blueprint to register. + :param url_prefix: Blueprint routes will be prefixed with this. + :param subdomain: Blueprint routes will match on this subdomain. + :param url_defaults: Blueprint routes will use these default values for + view arguments. + :param options: Additional keyword arguments are passed to + :class:`~flask.blueprints.BlueprintSetupState`. They can be + accessed in :meth:`~flask.Blueprint.record` callbacks. + + .. versionchanged:: 2.0.1 + The ``name`` option can be used to change the (pre-dotted) + name the blueprint is registered with. This allows the same + blueprint to be registered multiple times with unique names + for ``url_for``. + + .. versionadded:: 0.7 + """ + blueprint.register(self, options) + + def iter_blueprints(self) -> t.ValuesView["Blueprint"]: + """Iterates over all blueprints by the order they were registered. + + .. versionadded:: 0.11 + """ + return self.blueprints.values() + + @setupmethod + def add_url_rule( + self, + rule: str, + endpoint: t.Optional[str] = None, + view_func: t.Optional[t.Callable] = None, + provide_automatic_options: t.Optional[bool] = None, + **options: t.Any, + ) -> None: + if endpoint is None: + endpoint = _endpoint_from_view_func(view_func) # type: ignore + options["endpoint"] = endpoint + methods = options.pop("methods", None) + + # if the methods are not given and the view_func object knows its + # methods we can use that instead. If neither exists, we go with + # a tuple of only ``GET`` as default. + if methods is None: + methods = getattr(view_func, "methods", None) or ("GET",) + if isinstance(methods, str): + raise TypeError( + "Allowed methods must be a list of strings, for" + ' example: @app.route(..., methods=["POST"])' + ) + methods = {item.upper() for item in methods} + + # Methods that should always be added + required_methods = set(getattr(view_func, "required_methods", ())) + + # starting with Flask 0.8 the view_func object can disable and + # force-enable the automatic options handling. + if provide_automatic_options is None: + provide_automatic_options = getattr( + view_func, "provide_automatic_options", None + ) + + if provide_automatic_options is None: + if "OPTIONS" not in methods: + provide_automatic_options = True + required_methods.add("OPTIONS") + else: + provide_automatic_options = False + + # Add the required methods now. + methods |= required_methods + + rule = self.url_rule_class(rule, methods=methods, **options) + rule.provide_automatic_options = provide_automatic_options # type: ignore + + self.url_map.add(rule) + if view_func is not None: + old_func = self.view_functions.get(endpoint) + if old_func is not None and old_func != view_func: + raise AssertionError( + "View function mapping is overwriting an existing" + f" endpoint function: {endpoint}" + ) + self.view_functions[endpoint] = view_func + + @setupmethod + def template_filter( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateFilterCallable], TemplateFilterCallable]: + """A decorator that is used to register custom template filter. + You can specify a name for the filter, otherwise the function + name will be used. Example:: + + @app.template_filter() + def reverse(s): + return s[::-1] + + :param name: the optional name of the filter, otherwise the + function name will be used. + """ + + def decorator(f: TemplateFilterCallable) -> TemplateFilterCallable: + self.add_template_filter(f, name=name) + return f + + return decorator + + @setupmethod + def add_template_filter( + self, f: TemplateFilterCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template filter. Works exactly like the + :meth:`template_filter` decorator. + + :param name: the optional name of the filter, otherwise the + function name will be used. + """ + self.jinja_env.filters[name or f.__name__] = f + + @setupmethod + def template_test( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateTestCallable], TemplateTestCallable]: + """A decorator that is used to register custom template test. + You can specify a name for the test, otherwise the function + name will be used. Example:: + + @app.template_test() + def is_prime(n): + if n == 2: + return True + for i in range(2, int(math.ceil(math.sqrt(n))) + 1): + if n % i == 0: + return False + return True + + .. versionadded:: 0.10 + + :param name: the optional name of the test, otherwise the + function name will be used. + """ + + def decorator(f: TemplateTestCallable) -> TemplateTestCallable: + self.add_template_test(f, name=name) + return f + + return decorator + + @setupmethod + def add_template_test( + self, f: TemplateTestCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template test. Works exactly like the + :meth:`template_test` decorator. + + .. versionadded:: 0.10 + + :param name: the optional name of the test, otherwise the + function name will be used. + """ + self.jinja_env.tests[name or f.__name__] = f + + @setupmethod + def template_global( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateGlobalCallable], TemplateGlobalCallable]: + """A decorator that is used to register a custom template global function. + You can specify a name for the global function, otherwise the function + name will be used. Example:: + + @app.template_global() + def double(n): + return 2 * n + + .. versionadded:: 0.10 + + :param name: the optional name of the global function, otherwise the + function name will be used. + """ + + def decorator(f: TemplateGlobalCallable) -> TemplateGlobalCallable: + self.add_template_global(f, name=name) + return f + + return decorator + + @setupmethod + def add_template_global( + self, f: TemplateGlobalCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template global function. Works exactly like the + :meth:`template_global` decorator. + + .. versionadded:: 0.10 + + :param name: the optional name of the global function, otherwise the + function name will be used. + """ + self.jinja_env.globals[name or f.__name__] = f + + @setupmethod + def before_first_request( + self, f: BeforeFirstRequestCallable + ) -> BeforeFirstRequestCallable: + """Registers a function to be run before the first request to this + instance of the application. + + The function will be called without any arguments and its return + value is ignored. + + .. versionadded:: 0.8 + """ + self.before_first_request_funcs.append(f) + return f + + @setupmethod + def teardown_appcontext(self, f: TeardownCallable) -> TeardownCallable: + """Registers a function to be called when the application context + ends. These functions are typically also called when the request + context is popped. + + Example:: + + ctx = app.app_context() + ctx.push() + ... + ctx.pop() + + When ``ctx.pop()`` is executed in the above example, the teardown + functions are called just before the app context moves from the + stack of active contexts. This becomes relevant if you are using + such constructs in tests. + + Since a request context typically also manages an application + context it would also be called when you pop a request context. + + When a teardown function was called because of an unhandled exception + it will be passed an error object. If an :meth:`errorhandler` is + registered, it will handle the exception and the teardown will not + receive it. + + The return values of teardown functions are ignored. + + .. versionadded:: 0.9 + """ + self.teardown_appcontext_funcs.append(f) + return f + + @setupmethod + def shell_context_processor(self, f: t.Callable) -> t.Callable: + """Registers a shell context processor function. + + .. versionadded:: 0.11 + """ + self.shell_context_processors.append(f) + return f + + def _find_error_handler( + self, e: Exception + ) -> t.Optional["ErrorHandlerCallable[Exception]"]: + """Return a registered error handler for an exception in this order: + blueprint handler for a specific code, app handler for a specific code, + blueprint handler for an exception class, app handler for an exception + class, or ``None`` if a suitable handler is not found. + """ + exc_class, code = self._get_exc_class_and_code(type(e)) + names = (*request.blueprints, None) + + for c in (code, None) if code is not None else (None,): + for name in names: + handler_map = self.error_handler_spec[name][c] + + if not handler_map: + continue + + for cls in exc_class.__mro__: + handler = handler_map.get(cls) + + if handler is not None: + return handler + return None + + def handle_http_exception( + self, e: HTTPException + ) -> t.Union[HTTPException, ResponseReturnValue]: + """Handles an HTTP exception. By default this will invoke the + registered error handlers and fall back to returning the + exception as response. + + .. versionchanged:: 1.0.3 + ``RoutingException``, used internally for actions such as + slash redirects during routing, is not passed to error + handlers. + + .. versionchanged:: 1.0 + Exceptions are looked up by code *and* by MRO, so + ``HTTPException`` subclasses can be handled with a catch-all + handler for the base ``HTTPException``. + + .. versionadded:: 0.3 + """ + # Proxy exceptions don't have error codes. We want to always return + # those unchanged as errors + if e.code is None: + return e + + # RoutingExceptions are used internally to trigger routing + # actions, such as slash redirects raising RequestRedirect. They + # are not raised or handled in user code. + if isinstance(e, RoutingException): + return e + + handler = self._find_error_handler(e) + if handler is None: + return e + return self.ensure_sync(handler)(e) + + def trap_http_exception(self, e: Exception) -> bool: + """Checks if an HTTP exception should be trapped or not. By default + this will return ``False`` for all exceptions except for a bad request + key error if ``TRAP_BAD_REQUEST_ERRORS`` is set to ``True``. It + also returns ``True`` if ``TRAP_HTTP_EXCEPTIONS`` is set to ``True``. + + This is called for all HTTP exceptions raised by a view function. + If it returns ``True`` for any exception the error handler for this + exception is not called and it shows up as regular exception in the + traceback. This is helpful for debugging implicitly raised HTTP + exceptions. + + .. versionchanged:: 1.0 + Bad request errors are not trapped by default in debug mode. + + .. versionadded:: 0.8 + """ + if self.config["TRAP_HTTP_EXCEPTIONS"]: + return True + + trap_bad_request = self.config["TRAP_BAD_REQUEST_ERRORS"] + + # if unset, trap key errors in debug mode + if ( + trap_bad_request is None + and self.debug + and isinstance(e, BadRequestKeyError) + ): + return True + + if trap_bad_request: + return isinstance(e, BadRequest) + + return False + + def handle_user_exception( + self, e: Exception + ) -> t.Union[HTTPException, ResponseReturnValue]: + """This method is called whenever an exception occurs that + should be handled. A special case is :class:`~werkzeug + .exceptions.HTTPException` which is forwarded to the + :meth:`handle_http_exception` method. This function will either + return a response value or reraise the exception with the same + traceback. + + .. versionchanged:: 1.0 + Key errors raised from request data like ``form`` show the + bad key in debug mode rather than a generic bad request + message. + + .. versionadded:: 0.7 + """ + if isinstance(e, BadRequestKeyError) and ( + self.debug or self.config["TRAP_BAD_REQUEST_ERRORS"] + ): + e.show_exception = True + + if isinstance(e, HTTPException) and not self.trap_http_exception(e): + return self.handle_http_exception(e) + + handler = self._find_error_handler(e) + + if handler is None: + raise + + return self.ensure_sync(handler)(e) + + def handle_exception(self, e: Exception) -> Response: + """Handle an exception that did not have an error handler + associated with it, or that was raised from an error handler. + This always causes a 500 ``InternalServerError``. + + Always sends the :data:`got_request_exception` signal. + + If :attr:`propagate_exceptions` is ``True``, such as in debug + mode, the error will be re-raised so that the debugger can + display it. Otherwise, the original exception is logged, and + an :exc:`~werkzeug.exceptions.InternalServerError` is returned. + + If an error handler is registered for ``InternalServerError`` or + ``500``, it will be used. For consistency, the handler will + always receive the ``InternalServerError``. The original + unhandled exception is available as ``e.original_exception``. + + .. versionchanged:: 1.1.0 + Always passes the ``InternalServerError`` instance to the + handler, setting ``original_exception`` to the unhandled + error. + + .. versionchanged:: 1.1.0 + ``after_request`` functions and other finalization is done + even for the default 500 response when there is no handler. + + .. versionadded:: 0.3 + """ + exc_info = sys.exc_info() + got_request_exception.send(self, exception=e) + + if self.propagate_exceptions: + # Re-raise if called with an active exception, otherwise + # raise the passed in exception. + if exc_info[1] is e: + raise + + raise e + + self.log_exception(exc_info) + server_error: t.Union[InternalServerError, ResponseReturnValue] + server_error = InternalServerError(original_exception=e) + handler = self._find_error_handler(server_error) + + if handler is not None: + server_error = self.ensure_sync(handler)(server_error) + + return self.finalize_request(server_error, from_error_handler=True) + + def log_exception( + self, + exc_info: t.Union[ + t.Tuple[type, BaseException, TracebackType], t.Tuple[None, None, None] + ], + ) -> None: + """Logs an exception. This is called by :meth:`handle_exception` + if debugging is disabled and right before the handler is called. + The default implementation logs the exception as error on the + :attr:`logger`. + + .. versionadded:: 0.8 + """ + self.logger.error( + f"Exception on {request.path} [{request.method}]", exc_info=exc_info + ) + + def raise_routing_exception(self, request: Request) -> "te.NoReturn": + """Exceptions that are recording during routing are reraised with + this method. During debug we are not reraising redirect requests + for non ``GET``, ``HEAD``, or ``OPTIONS`` requests and we're raising + a different error instead to help debug situations. + + :internal: + """ + if ( + not self.debug + or not isinstance(request.routing_exception, RequestRedirect) + or request.method in ("GET", "HEAD", "OPTIONS") + ): + raise request.routing_exception # type: ignore + + from .debughelpers import FormDataRoutingRedirect + + raise FormDataRoutingRedirect(request) + + def dispatch_request(self) -> ResponseReturnValue: + """Does the request dispatching. Matches the URL and returns the + return value of the view or error handler. This does not have to + be a response object. In order to convert the return value to a + proper response object, call :func:`make_response`. + + .. versionchanged:: 0.7 + This no longer does the exception handling, this code was + moved to the new :meth:`full_dispatch_request`. + """ + req = _request_ctx_stack.top.request + if req.routing_exception is not None: + self.raise_routing_exception(req) + rule = req.url_rule + # if we provide automatic options for this URL and the + # request came with the OPTIONS method, reply automatically + if ( + getattr(rule, "provide_automatic_options", False) + and req.method == "OPTIONS" + ): + return self.make_default_options_response() + # otherwise dispatch to the handler for that endpoint + return self.ensure_sync(self.view_functions[rule.endpoint])(**req.view_args) + + def full_dispatch_request(self) -> Response: + """Dispatches the request and on top of that performs request + pre and postprocessing as well as HTTP exception catching and + error handling. + + .. versionadded:: 0.7 + """ + self.try_trigger_before_first_request_functions() + try: + request_started.send(self) + rv = self.preprocess_request() + if rv is None: + rv = self.dispatch_request() + except Exception as e: + rv = self.handle_user_exception(e) + return self.finalize_request(rv) + + def finalize_request( + self, + rv: t.Union[ResponseReturnValue, HTTPException], + from_error_handler: bool = False, + ) -> Response: + """Given the return value from a view function this finalizes + the request by converting it into a response and invoking the + postprocessing functions. This is invoked for both normal + request dispatching as well as error handlers. + + Because this means that it might be called as a result of a + failure a special safe mode is available which can be enabled + with the `from_error_handler` flag. If enabled, failures in + response processing will be logged and otherwise ignored. + + :internal: + """ + response = self.make_response(rv) + try: + response = self.process_response(response) + request_finished.send(self, response=response) + except Exception: + if not from_error_handler: + raise + self.logger.exception( + "Request finalizing failed with an error while handling an error" + ) + return response + + def try_trigger_before_first_request_functions(self) -> None: + """Called before each request and will ensure that it triggers + the :attr:`before_first_request_funcs` and only exactly once per + application instance (which means process usually). + + :internal: + """ + if self._got_first_request: + return + with self._before_request_lock: + if self._got_first_request: + return + for func in self.before_first_request_funcs: + self.ensure_sync(func)() + self._got_first_request = True + + def make_default_options_response(self) -> Response: + """This method is called to create the default ``OPTIONS`` response. + This can be changed through subclassing to change the default + behavior of ``OPTIONS`` responses. + + .. versionadded:: 0.7 + """ + adapter = _request_ctx_stack.top.url_adapter + methods = adapter.allowed_methods() + rv = self.response_class() + rv.allow.update(methods) + return rv + + def should_ignore_error(self, error: t.Optional[BaseException]) -> bool: + """This is called to figure out if an error should be ignored + or not as far as the teardown system is concerned. If this + function returns ``True`` then the teardown handlers will not be + passed the error. + + .. versionadded:: 0.10 + """ + return False + + def ensure_sync(self, func: t.Callable) -> t.Callable: + """Ensure that the function is synchronous for WSGI workers. + Plain ``def`` functions are returned as-is. ``async def`` + functions are wrapped to run and wait for the response. + + Override this method to change how the app runs async views. + + .. versionadded:: 2.0 + """ + if iscoroutinefunction(func): + return self.async_to_sync(func) + + return func + + def async_to_sync( + self, func: t.Callable[..., t.Coroutine] + ) -> t.Callable[..., t.Any]: + """Return a sync function that will run the coroutine function. + + .. code-block:: python + + result = app.async_to_sync(func)(*args, **kwargs) + + Override this method to change how the app converts async code + to be synchronously callable. + + .. versionadded:: 2.0 + """ + try: + from asgiref.sync import async_to_sync as asgiref_async_to_sync + except ImportError: + raise RuntimeError( + "Install Flask with the 'async' extra in order to use async views." + ) from None + + # Check that Werkzeug isn't using its fallback ContextVar class. + if ContextVar.__module__ == "werkzeug.local": + raise RuntimeError( + "Async cannot be used with this combination of Python " + "and Greenlet versions." + ) + + return asgiref_async_to_sync(func) + + def make_response(self, rv: ResponseReturnValue) -> Response: + """Convert the return value from a view function to an instance of + :attr:`response_class`. + + :param rv: the return value from the view function. The view function + must return a response. Returning ``None``, or the view ending + without returning, is not allowed. The following types are allowed + for ``view_rv``: + + ``str`` + A response object is created with the string encoded to UTF-8 + as the body. + + ``bytes`` + A response object is created with the bytes as the body. + + ``dict`` + A dictionary that will be jsonify'd before being returned. + + ``tuple`` + Either ``(body, status, headers)``, ``(body, status)``, or + ``(body, headers)``, where ``body`` is any of the other types + allowed here, ``status`` is a string or an integer, and + ``headers`` is a dictionary or a list of ``(key, value)`` + tuples. If ``body`` is a :attr:`response_class` instance, + ``status`` overwrites the exiting value and ``headers`` are + extended. + + :attr:`response_class` + The object is returned unchanged. + + other :class:`~werkzeug.wrappers.Response` class + The object is coerced to :attr:`response_class`. + + :func:`callable` + The function is called as a WSGI application. The result is + used to create a response object. + + .. versionchanged:: 0.9 + Previously a tuple was interpreted as the arguments for the + response object. + """ + + status = headers = None + + # unpack tuple returns + if isinstance(rv, tuple): + len_rv = len(rv) + + # a 3-tuple is unpacked directly + if len_rv == 3: + rv, status, headers = rv + # decide if a 2-tuple has status or headers + elif len_rv == 2: + if isinstance(rv[1], (Headers, dict, tuple, list)): + rv, headers = rv + else: + rv, status = rv + # other sized tuples are not allowed + else: + raise TypeError( + "The view function did not return a valid response tuple." + " The tuple must have the form (body, status, headers)," + " (body, status), or (body, headers)." + ) + + # the body must not be None + if rv is None: + raise TypeError( + f"The view function for {request.endpoint!r} did not" + " return a valid response. The function either returned" + " None or ended without a return statement." + ) + + # make sure the body is an instance of the response class + if not isinstance(rv, self.response_class): + if isinstance(rv, (str, bytes, bytearray)): + # let the response class set the status and headers instead of + # waiting to do it manually, so that the class can handle any + # special logic + rv = self.response_class(rv, status=status, headers=headers) + status = headers = None + elif isinstance(rv, dict): + rv = jsonify(rv) + elif isinstance(rv, BaseResponse) or callable(rv): + # evaluate a WSGI callable, or coerce a different response + # class to the correct type + try: + rv = self.response_class.force_type(rv, request.environ) # type: ignore # noqa: B950 + except TypeError as e: + raise TypeError( + f"{e}\nThe view function did not return a valid" + " response. The return type must be a string," + " dict, tuple, Response instance, or WSGI" + f" callable, but it was a {type(rv).__name__}." + ).with_traceback(sys.exc_info()[2]) from None + else: + raise TypeError( + "The view function did not return a valid" + " response. The return type must be a string," + " dict, tuple, Response instance, or WSGI" + f" callable, but it was a {type(rv).__name__}." + ) + + rv = t.cast(Response, rv) + # prefer the status if it was provided + if status is not None: + if isinstance(status, (str, bytes, bytearray)): + rv.status = status # type: ignore + else: + rv.status_code = status + + # extend existing headers with provided headers + if headers: + rv.headers.update(headers) + + return rv + + def create_url_adapter( + self, request: t.Optional[Request] + ) -> t.Optional[MapAdapter]: + """Creates a URL adapter for the given request. The URL adapter + is created at a point where the request context is not yet set + up so the request is passed explicitly. + + .. versionadded:: 0.6 + + .. versionchanged:: 0.9 + This can now also be called without a request object when the + URL adapter is created for the application context. + + .. versionchanged:: 1.0 + :data:`SERVER_NAME` no longer implicitly enables subdomain + matching. Use :attr:`subdomain_matching` instead. + """ + if request is not None: + # If subdomain matching is disabled (the default), use the + # default subdomain in all cases. This should be the default + # in Werkzeug but it currently does not have that feature. + if not self.subdomain_matching: + subdomain = self.url_map.default_subdomain or None + else: + subdomain = None + + return self.url_map.bind_to_environ( + request.environ, + server_name=self.config["SERVER_NAME"], + subdomain=subdomain, + ) + # We need at the very least the server name to be set for this + # to work. + if self.config["SERVER_NAME"] is not None: + return self.url_map.bind( + self.config["SERVER_NAME"], + script_name=self.config["APPLICATION_ROOT"], + url_scheme=self.config["PREFERRED_URL_SCHEME"], + ) + + return None + + def inject_url_defaults(self, endpoint: str, values: dict) -> None: + """Injects the URL defaults for the given endpoint directly into + the values dictionary passed. This is used internally and + automatically called on URL building. + + .. versionadded:: 0.7 + """ + names: t.Iterable[t.Optional[str]] = (None,) + + # url_for may be called outside a request context, parse the + # passed endpoint instead of using request.blueprints. + if "." in endpoint: + names = chain( + names, reversed(_split_blueprint_path(endpoint.rpartition(".")[0])) + ) + + for name in names: + if name in self.url_default_functions: + for func in self.url_default_functions[name]: + func(endpoint, values) + + def handle_url_build_error( + self, error: Exception, endpoint: str, values: dict + ) -> str: + """Handle :class:`~werkzeug.routing.BuildError` on + :meth:`url_for`. + """ + for handler in self.url_build_error_handlers: + try: + rv = handler(error, endpoint, values) + except BuildError as e: + # make error available outside except block + error = e + else: + if rv is not None: + return rv + + # Re-raise if called with an active exception, otherwise raise + # the passed in exception. + if error is sys.exc_info()[1]: + raise + + raise error + + def preprocess_request(self) -> t.Optional[ResponseReturnValue]: + """Called before the request is dispatched. Calls + :attr:`url_value_preprocessors` registered with the app and the + current blueprint (if any). Then calls :attr:`before_request_funcs` + registered with the app and the blueprint. + + If any :meth:`before_request` handler returns a non-None value, the + value is handled as if it was the return value from the view, and + further request handling is stopped. + """ + names = (None, *reversed(request.blueprints)) + + for name in names: + if name in self.url_value_preprocessors: + for url_func in self.url_value_preprocessors[name]: + url_func(request.endpoint, request.view_args) + + for name in names: + if name in self.before_request_funcs: + for before_func in self.before_request_funcs[name]: + rv = self.ensure_sync(before_func)() + + if rv is not None: + return rv + + return None + + def process_response(self, response: Response) -> Response: + """Can be overridden in order to modify the response object + before it's sent to the WSGI server. By default this will + call all the :meth:`after_request` decorated functions. + + .. versionchanged:: 0.5 + As of Flask 0.5 the functions registered for after request + execution are called in reverse order of registration. + + :param response: a :attr:`response_class` object. + :return: a new response object or the same, has to be an + instance of :attr:`response_class`. + """ + ctx = _request_ctx_stack.top + + for func in ctx._after_request_functions: + response = self.ensure_sync(func)(response) + + for name in chain(request.blueprints, (None,)): + if name in self.after_request_funcs: + for func in reversed(self.after_request_funcs[name]): + response = self.ensure_sync(func)(response) + + if not self.session_interface.is_null_session(ctx.session): + self.session_interface.save_session(self, ctx.session, response) + + return response + + def do_teardown_request( + self, exc: t.Optional[BaseException] = _sentinel # type: ignore + ) -> None: + """Called after the request is dispatched and the response is + returned, right before the request context is popped. + + This calls all functions decorated with + :meth:`teardown_request`, and :meth:`Blueprint.teardown_request` + if a blueprint handled the request. Finally, the + :data:`request_tearing_down` signal is sent. + + This is called by + :meth:`RequestContext.pop() `, + which may be delayed during testing to maintain access to + resources. + + :param exc: An unhandled exception raised while dispatching the + request. Detected from the current exception information if + not passed. Passed to each teardown function. + + .. versionchanged:: 0.9 + Added the ``exc`` argument. + """ + if exc is _sentinel: + exc = sys.exc_info()[1] + + for name in chain(request.blueprints, (None,)): + if name in self.teardown_request_funcs: + for func in reversed(self.teardown_request_funcs[name]): + self.ensure_sync(func)(exc) + + request_tearing_down.send(self, exc=exc) + + def do_teardown_appcontext( + self, exc: t.Optional[BaseException] = _sentinel # type: ignore + ) -> None: + """Called right before the application context is popped. + + When handling a request, the application context is popped + after the request context. See :meth:`do_teardown_request`. + + This calls all functions decorated with + :meth:`teardown_appcontext`. Then the + :data:`appcontext_tearing_down` signal is sent. + + This is called by + :meth:`AppContext.pop() `. + + .. versionadded:: 0.9 + """ + if exc is _sentinel: + exc = sys.exc_info()[1] + + for func in reversed(self.teardown_appcontext_funcs): + self.ensure_sync(func)(exc) + + appcontext_tearing_down.send(self, exc=exc) + + def app_context(self) -> AppContext: + """Create an :class:`~flask.ctx.AppContext`. Use as a ``with`` + block to push the context, which will make :data:`current_app` + point at this application. + + An application context is automatically pushed by + :meth:`RequestContext.push() ` + when handling a request, and when running a CLI command. Use + this to manually create a context outside of these situations. + + :: + + with app.app_context(): + init_db() + + See :doc:`/appcontext`. + + .. versionadded:: 0.9 + """ + return AppContext(self) + + def request_context(self, environ: dict) -> RequestContext: + """Create a :class:`~flask.ctx.RequestContext` representing a + WSGI environment. Use a ``with`` block to push the context, + which will make :data:`request` point at this request. + + See :doc:`/reqcontext`. + + Typically you should not call this from your own code. A request + context is automatically pushed by the :meth:`wsgi_app` when + handling a request. Use :meth:`test_request_context` to create + an environment and context instead of this method. + + :param environ: a WSGI environment + """ + return RequestContext(self, environ) + + def test_request_context(self, *args: t.Any, **kwargs: t.Any) -> RequestContext: + """Create a :class:`~flask.ctx.RequestContext` for a WSGI + environment created from the given values. This is mostly useful + during testing, where you may want to run a function that uses + request data without dispatching a full request. + + See :doc:`/reqcontext`. + + Use a ``with`` block to push the context, which will make + :data:`request` point at the request for the created + environment. :: + + with test_request_context(...): + generate_report() + + When using the shell, it may be easier to push and pop the + context manually to avoid indentation. :: + + ctx = app.test_request_context(...) + ctx.push() + ... + ctx.pop() + + Takes the same arguments as Werkzeug's + :class:`~werkzeug.test.EnvironBuilder`, with some defaults from + the application. See the linked Werkzeug docs for most of the + available arguments. Flask-specific behavior is listed here. + + :param path: URL path being requested. + :param base_url: Base URL where the app is being served, which + ``path`` is relative to. If not given, built from + :data:`PREFERRED_URL_SCHEME`, ``subdomain``, + :data:`SERVER_NAME`, and :data:`APPLICATION_ROOT`. + :param subdomain: Subdomain name to append to + :data:`SERVER_NAME`. + :param url_scheme: Scheme to use instead of + :data:`PREFERRED_URL_SCHEME`. + :param data: The request body, either as a string or a dict of + form keys and values. + :param json: If given, this is serialized as JSON and passed as + ``data``. Also defaults ``content_type`` to + ``application/json``. + :param args: other positional arguments passed to + :class:`~werkzeug.test.EnvironBuilder`. + :param kwargs: other keyword arguments passed to + :class:`~werkzeug.test.EnvironBuilder`. + """ + from .testing import EnvironBuilder + + builder = EnvironBuilder(self, *args, **kwargs) + + try: + return self.request_context(builder.get_environ()) + finally: + builder.close() + + def wsgi_app(self, environ: dict, start_response: t.Callable) -> t.Any: + """The actual WSGI application. This is not implemented in + :meth:`__call__` so that middlewares can be applied without + losing a reference to the app object. Instead of doing this:: + + app = MyMiddleware(app) + + It's a better idea to do this instead:: + + app.wsgi_app = MyMiddleware(app.wsgi_app) + + Then you still have the original application object around and + can continue to call methods on it. + + .. versionchanged:: 0.7 + Teardown events for the request and app contexts are called + even if an unhandled error occurs. Other events may not be + called depending on when an error occurs during dispatch. + See :ref:`callbacks-and-errors`. + + :param environ: A WSGI environment. + :param start_response: A callable accepting a status code, + a list of headers, and an optional exception context to + start the response. + """ + ctx = self.request_context(environ) + error: t.Optional[BaseException] = None + try: + try: + ctx.push() + response = self.full_dispatch_request() + except Exception as e: + error = e + response = self.handle_exception(e) + except: # noqa: B001 + error = sys.exc_info()[1] + raise + return response(environ, start_response) + finally: + if self.should_ignore_error(error): + error = None + ctx.auto_pop(error) + + def __call__(self, environ: dict, start_response: t.Callable) -> t.Any: + """The WSGI server calls the Flask application object as the + WSGI application. This calls :meth:`wsgi_app`, which can be + wrapped to apply middleware. + """ + return self.wsgi_app(environ, start_response) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/blueprints.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/blueprints.py new file mode 100644 index 00000000..5c23a735 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/blueprints.py @@ -0,0 +1,609 @@ +import os +import typing as t +from collections import defaultdict +from functools import update_wrapper + +from .scaffold import _endpoint_from_view_func +from .scaffold import _sentinel +from .scaffold import Scaffold +from .typing import AfterRequestCallable +from .typing import BeforeFirstRequestCallable +from .typing import BeforeRequestCallable +from .typing import TeardownCallable +from .typing import TemplateContextProcessorCallable +from .typing import TemplateFilterCallable +from .typing import TemplateGlobalCallable +from .typing import TemplateTestCallable +from .typing import URLDefaultCallable +from .typing import URLValuePreprocessorCallable + +if t.TYPE_CHECKING: + from .app import Flask + from .typing import ErrorHandlerCallable + +DeferredSetupFunction = t.Callable[["BlueprintSetupState"], t.Callable] + + +class BlueprintSetupState: + """Temporary holder object for registering a blueprint with the + application. An instance of this class is created by the + :meth:`~flask.Blueprint.make_setup_state` method and later passed + to all register callback functions. + """ + + def __init__( + self, + blueprint: "Blueprint", + app: "Flask", + options: t.Any, + first_registration: bool, + ) -> None: + #: a reference to the current application + self.app = app + + #: a reference to the blueprint that created this setup state. + self.blueprint = blueprint + + #: a dictionary with all options that were passed to the + #: :meth:`~flask.Flask.register_blueprint` method. + self.options = options + + #: as blueprints can be registered multiple times with the + #: application and not everything wants to be registered + #: multiple times on it, this attribute can be used to figure + #: out if the blueprint was registered in the past already. + self.first_registration = first_registration + + subdomain = self.options.get("subdomain") + if subdomain is None: + subdomain = self.blueprint.subdomain + + #: The subdomain that the blueprint should be active for, ``None`` + #: otherwise. + self.subdomain = subdomain + + url_prefix = self.options.get("url_prefix") + if url_prefix is None: + url_prefix = self.blueprint.url_prefix + #: The prefix that should be used for all URLs defined on the + #: blueprint. + self.url_prefix = url_prefix + + self.name = self.options.get("name", blueprint.name) + self.name_prefix = self.options.get("name_prefix", "") + + #: A dictionary with URL defaults that is added to each and every + #: URL that was defined with the blueprint. + self.url_defaults = dict(self.blueprint.url_values_defaults) + self.url_defaults.update(self.options.get("url_defaults", ())) + + def add_url_rule( + self, + rule: str, + endpoint: t.Optional[str] = None, + view_func: t.Optional[t.Callable] = None, + **options: t.Any, + ) -> None: + """A helper method to register a rule (and optionally a view function) + to the application. The endpoint is automatically prefixed with the + blueprint's name. + """ + if self.url_prefix is not None: + if rule: + rule = "/".join((self.url_prefix.rstrip("/"), rule.lstrip("/"))) + else: + rule = self.url_prefix + options.setdefault("subdomain", self.subdomain) + if endpoint is None: + endpoint = _endpoint_from_view_func(view_func) # type: ignore + defaults = self.url_defaults + if "defaults" in options: + defaults = dict(defaults, **options.pop("defaults")) + + self.app.add_url_rule( + rule, + f"{self.name_prefix}.{self.name}.{endpoint}".lstrip("."), + view_func, + defaults=defaults, + **options, + ) + + +class Blueprint(Scaffold): + """Represents a blueprint, a collection of routes and other + app-related functions that can be registered on a real application + later. + + A blueprint is an object that allows defining application functions + without requiring an application object ahead of time. It uses the + same decorators as :class:`~flask.Flask`, but defers the need for an + application by recording them for later registration. + + Decorating a function with a blueprint creates a deferred function + that is called with :class:`~flask.blueprints.BlueprintSetupState` + when the blueprint is registered on an application. + + See :doc:`/blueprints` for more information. + + :param name: The name of the blueprint. Will be prepended to each + endpoint name. + :param import_name: The name of the blueprint package, usually + ``__name__``. This helps locate the ``root_path`` for the + blueprint. + :param static_folder: A folder with static files that should be + served by the blueprint's static route. The path is relative to + the blueprint's root path. Blueprint static files are disabled + by default. + :param static_url_path: The url to serve static files from. + Defaults to ``static_folder``. If the blueprint does not have + a ``url_prefix``, the app's static route will take precedence, + and the blueprint's static files won't be accessible. + :param template_folder: A folder with templates that should be added + to the app's template search path. The path is relative to the + blueprint's root path. Blueprint templates are disabled by + default. Blueprint templates have a lower precedence than those + in the app's templates folder. + :param url_prefix: A path to prepend to all of the blueprint's URLs, + to make them distinct from the rest of the app's routes. + :param subdomain: A subdomain that blueprint routes will match on by + default. + :param url_defaults: A dict of default values that blueprint routes + will receive by default. + :param root_path: By default, the blueprint will automatically set + this based on ``import_name``. In certain situations this + automatic detection can fail, so the path can be specified + manually instead. + + .. versionchanged:: 1.1.0 + Blueprints have a ``cli`` group to register nested CLI commands. + The ``cli_group`` parameter controls the name of the group under + the ``flask`` command. + + .. versionadded:: 0.7 + """ + + warn_on_modifications = False + _got_registered_once = False + + #: Blueprint local JSON encoder class to use. Set to ``None`` to use + #: the app's :class:`~flask.Flask.json_encoder`. + json_encoder = None + #: Blueprint local JSON decoder class to use. Set to ``None`` to use + #: the app's :class:`~flask.Flask.json_decoder`. + json_decoder = None + + def __init__( + self, + name: str, + import_name: str, + static_folder: t.Optional[t.Union[str, os.PathLike]] = None, + static_url_path: t.Optional[str] = None, + template_folder: t.Optional[str] = None, + url_prefix: t.Optional[str] = None, + subdomain: t.Optional[str] = None, + url_defaults: t.Optional[dict] = None, + root_path: t.Optional[str] = None, + cli_group: t.Optional[str] = _sentinel, # type: ignore + ): + super().__init__( + import_name=import_name, + static_folder=static_folder, + static_url_path=static_url_path, + template_folder=template_folder, + root_path=root_path, + ) + + if "." in name: + raise ValueError("'name' may not contain a dot '.' character.") + + self.name = name + self.url_prefix = url_prefix + self.subdomain = subdomain + self.deferred_functions: t.List[DeferredSetupFunction] = [] + + if url_defaults is None: + url_defaults = {} + + self.url_values_defaults = url_defaults + self.cli_group = cli_group + self._blueprints: t.List[t.Tuple["Blueprint", dict]] = [] + + def _is_setup_finished(self) -> bool: + return self.warn_on_modifications and self._got_registered_once + + def record(self, func: t.Callable) -> None: + """Registers a function that is called when the blueprint is + registered on the application. This function is called with the + state as argument as returned by the :meth:`make_setup_state` + method. + """ + if self._got_registered_once and self.warn_on_modifications: + from warnings import warn + + warn( + Warning( + "The blueprint was already registered once but is" + " getting modified now. These changes will not show" + " up." + ) + ) + self.deferred_functions.append(func) + + def record_once(self, func: t.Callable) -> None: + """Works like :meth:`record` but wraps the function in another + function that will ensure the function is only called once. If the + blueprint is registered a second time on the application, the + function passed is not called. + """ + + def wrapper(state: BlueprintSetupState) -> None: + if state.first_registration: + func(state) + + return self.record(update_wrapper(wrapper, func)) + + def make_setup_state( + self, app: "Flask", options: dict, first_registration: bool = False + ) -> BlueprintSetupState: + """Creates an instance of :meth:`~flask.blueprints.BlueprintSetupState` + object that is later passed to the register callback functions. + Subclasses can override this to return a subclass of the setup state. + """ + return BlueprintSetupState(self, app, options, first_registration) + + def register_blueprint(self, blueprint: "Blueprint", **options: t.Any) -> None: + """Register a :class:`~flask.Blueprint` on this blueprint. Keyword + arguments passed to this method will override the defaults set + on the blueprint. + + .. versionchanged:: 2.0.1 + The ``name`` option can be used to change the (pre-dotted) + name the blueprint is registered with. This allows the same + blueprint to be registered multiple times with unique names + for ``url_for``. + + .. versionadded:: 2.0 + """ + if blueprint is self: + raise ValueError("Cannot register a blueprint on itself") + self._blueprints.append((blueprint, options)) + + def register(self, app: "Flask", options: dict) -> None: + """Called by :meth:`Flask.register_blueprint` to register all + views and callbacks registered on the blueprint with the + application. Creates a :class:`.BlueprintSetupState` and calls + each :meth:`record` callback with it. + + :param app: The application this blueprint is being registered + with. + :param options: Keyword arguments forwarded from + :meth:`~Flask.register_blueprint`. + + .. versionchanged:: 2.0.1 + Nested blueprints are registered with their dotted name. + This allows different blueprints with the same name to be + nested at different locations. + + .. versionchanged:: 2.0.1 + The ``name`` option can be used to change the (pre-dotted) + name the blueprint is registered with. This allows the same + blueprint to be registered multiple times with unique names + for ``url_for``. + + .. versionchanged:: 2.0.1 + Registering the same blueprint with the same name multiple + times is deprecated and will become an error in Flask 2.1. + """ + name_prefix = options.get("name_prefix", "") + self_name = options.get("name", self.name) + name = f"{name_prefix}.{self_name}".lstrip(".") + + if name in app.blueprints: + existing_at = f" '{name}'" if self_name != name else "" + + if app.blueprints[name] is not self: + raise ValueError( + f"The name '{self_name}' is already registered for" + f" a different blueprint{existing_at}. Use 'name='" + " to provide a unique name." + ) + else: + import warnings + + warnings.warn( + f"The name '{self_name}' is already registered for" + f" this blueprint{existing_at}. Use 'name=' to" + " provide a unique name. This will become an error" + " in Flask 2.1.", + stacklevel=4, + ) + + first_bp_registration = not any(bp is self for bp in app.blueprints.values()) + first_name_registration = name not in app.blueprints + + app.blueprints[name] = self + self._got_registered_once = True + state = self.make_setup_state(app, options, first_bp_registration) + + if self.has_static_folder: + state.add_url_rule( + f"{self.static_url_path}/", + view_func=self.send_static_file, + endpoint="static", + ) + + # Merge blueprint data into parent. + if first_bp_registration or first_name_registration: + + def extend(bp_dict, parent_dict): + for key, values in bp_dict.items(): + key = name if key is None else f"{name}.{key}" + parent_dict[key].extend(values) + + for key, value in self.error_handler_spec.items(): + key = name if key is None else f"{name}.{key}" + value = defaultdict( + dict, + { + code: { + exc_class: func for exc_class, func in code_values.items() + } + for code, code_values in value.items() + }, + ) + app.error_handler_spec[key] = value + + for endpoint, func in self.view_functions.items(): + app.view_functions[endpoint] = func + + extend(self.before_request_funcs, app.before_request_funcs) + extend(self.after_request_funcs, app.after_request_funcs) + extend( + self.teardown_request_funcs, + app.teardown_request_funcs, + ) + extend(self.url_default_functions, app.url_default_functions) + extend(self.url_value_preprocessors, app.url_value_preprocessors) + extend(self.template_context_processors, app.template_context_processors) + + for deferred in self.deferred_functions: + deferred(state) + + cli_resolved_group = options.get("cli_group", self.cli_group) + + if self.cli.commands: + if cli_resolved_group is None: + app.cli.commands.update(self.cli.commands) + elif cli_resolved_group is _sentinel: + self.cli.name = name + app.cli.add_command(self.cli) + else: + self.cli.name = cli_resolved_group + app.cli.add_command(self.cli) + + for blueprint, bp_options in self._blueprints: + bp_options = bp_options.copy() + bp_url_prefix = bp_options.get("url_prefix") + + if bp_url_prefix is None: + bp_url_prefix = blueprint.url_prefix + + if state.url_prefix is not None and bp_url_prefix is not None: + bp_options["url_prefix"] = ( + state.url_prefix.rstrip("/") + "/" + bp_url_prefix.lstrip("/") + ) + elif bp_url_prefix is not None: + bp_options["url_prefix"] = bp_url_prefix + elif state.url_prefix is not None: + bp_options["url_prefix"] = state.url_prefix + + bp_options["name_prefix"] = name + blueprint.register(app, bp_options) + + def add_url_rule( + self, + rule: str, + endpoint: t.Optional[str] = None, + view_func: t.Optional[t.Callable] = None, + provide_automatic_options: t.Optional[bool] = None, + **options: t.Any, + ) -> None: + """Like :meth:`Flask.add_url_rule` but for a blueprint. The endpoint for + the :func:`url_for` function is prefixed with the name of the blueprint. + """ + if endpoint and "." in endpoint: + raise ValueError("'endpoint' may not contain a dot '.' character.") + + if view_func and hasattr(view_func, "__name__") and "." in view_func.__name__: + raise ValueError("'view_func' name may not contain a dot '.' character.") + + self.record( + lambda s: s.add_url_rule( + rule, + endpoint, + view_func, + provide_automatic_options=provide_automatic_options, + **options, + ) + ) + + def app_template_filter( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateFilterCallable], TemplateFilterCallable]: + """Register a custom template filter, available application wide. Like + :meth:`Flask.template_filter` but for a blueprint. + + :param name: the optional name of the filter, otherwise the + function name will be used. + """ + + def decorator(f: TemplateFilterCallable) -> TemplateFilterCallable: + self.add_app_template_filter(f, name=name) + return f + + return decorator + + def add_app_template_filter( + self, f: TemplateFilterCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template filter, available application wide. Like + :meth:`Flask.add_template_filter` but for a blueprint. Works exactly + like the :meth:`app_template_filter` decorator. + + :param name: the optional name of the filter, otherwise the + function name will be used. + """ + + def register_template(state: BlueprintSetupState) -> None: + state.app.jinja_env.filters[name or f.__name__] = f + + self.record_once(register_template) + + def app_template_test( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateTestCallable], TemplateTestCallable]: + """Register a custom template test, available application wide. Like + :meth:`Flask.template_test` but for a blueprint. + + .. versionadded:: 0.10 + + :param name: the optional name of the test, otherwise the + function name will be used. + """ + + def decorator(f: TemplateTestCallable) -> TemplateTestCallable: + self.add_app_template_test(f, name=name) + return f + + return decorator + + def add_app_template_test( + self, f: TemplateTestCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template test, available application wide. Like + :meth:`Flask.add_template_test` but for a blueprint. Works exactly + like the :meth:`app_template_test` decorator. + + .. versionadded:: 0.10 + + :param name: the optional name of the test, otherwise the + function name will be used. + """ + + def register_template(state: BlueprintSetupState) -> None: + state.app.jinja_env.tests[name or f.__name__] = f + + self.record_once(register_template) + + def app_template_global( + self, name: t.Optional[str] = None + ) -> t.Callable[[TemplateGlobalCallable], TemplateGlobalCallable]: + """Register a custom template global, available application wide. Like + :meth:`Flask.template_global` but for a blueprint. + + .. versionadded:: 0.10 + + :param name: the optional name of the global, otherwise the + function name will be used. + """ + + def decorator(f: TemplateGlobalCallable) -> TemplateGlobalCallable: + self.add_app_template_global(f, name=name) + return f + + return decorator + + def add_app_template_global( + self, f: TemplateGlobalCallable, name: t.Optional[str] = None + ) -> None: + """Register a custom template global, available application wide. Like + :meth:`Flask.add_template_global` but for a blueprint. Works exactly + like the :meth:`app_template_global` decorator. + + .. versionadded:: 0.10 + + :param name: the optional name of the global, otherwise the + function name will be used. + """ + + def register_template(state: BlueprintSetupState) -> None: + state.app.jinja_env.globals[name or f.__name__] = f + + self.record_once(register_template) + + def before_app_request(self, f: BeforeRequestCallable) -> BeforeRequestCallable: + """Like :meth:`Flask.before_request`. Such a function is executed + before each request, even if outside of a blueprint. + """ + self.record_once( + lambda s: s.app.before_request_funcs.setdefault(None, []).append(f) + ) + return f + + def before_app_first_request( + self, f: BeforeFirstRequestCallable + ) -> BeforeFirstRequestCallable: + """Like :meth:`Flask.before_first_request`. Such a function is + executed before the first request to the application. + """ + self.record_once(lambda s: s.app.before_first_request_funcs.append(f)) + return f + + def after_app_request(self, f: AfterRequestCallable) -> AfterRequestCallable: + """Like :meth:`Flask.after_request` but for a blueprint. Such a function + is executed after each request, even if outside of the blueprint. + """ + self.record_once( + lambda s: s.app.after_request_funcs.setdefault(None, []).append(f) + ) + return f + + def teardown_app_request(self, f: TeardownCallable) -> TeardownCallable: + """Like :meth:`Flask.teardown_request` but for a blueprint. Such a + function is executed when tearing down each request, even if outside of + the blueprint. + """ + self.record_once( + lambda s: s.app.teardown_request_funcs.setdefault(None, []).append(f) + ) + return f + + def app_context_processor( + self, f: TemplateContextProcessorCallable + ) -> TemplateContextProcessorCallable: + """Like :meth:`Flask.context_processor` but for a blueprint. Such a + function is executed each request, even if outside of the blueprint. + """ + self.record_once( + lambda s: s.app.template_context_processors.setdefault(None, []).append(f) + ) + return f + + def app_errorhandler(self, code: t.Union[t.Type[Exception], int]) -> t.Callable: + """Like :meth:`Flask.errorhandler` but for a blueprint. This + handler is used for all requests, even if outside of the blueprint. + """ + + def decorator( + f: "ErrorHandlerCallable[Exception]", + ) -> "ErrorHandlerCallable[Exception]": + self.record_once(lambda s: s.app.errorhandler(code)(f)) + return f + + return decorator + + def app_url_value_preprocessor( + self, f: URLValuePreprocessorCallable + ) -> URLValuePreprocessorCallable: + """Same as :meth:`url_value_preprocessor` but application wide.""" + self.record_once( + lambda s: s.app.url_value_preprocessors.setdefault(None, []).append(f) + ) + return f + + def app_url_defaults(self, f: URLDefaultCallable) -> URLDefaultCallable: + """Same as :meth:`url_defaults` but application wide.""" + self.record_once( + lambda s: s.app.url_default_functions.setdefault(None, []).append(f) + ) + return f diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/cli.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/cli.py new file mode 100644 index 00000000..7ab4fa1c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/cli.py @@ -0,0 +1,998 @@ +import ast +import inspect +import os +import platform +import re +import sys +import traceback +import warnings +from functools import update_wrapper +from operator import attrgetter +from threading import Lock +from threading import Thread + +import click +from werkzeug.utils import import_string + +from .globals import current_app +from .helpers import get_debug_flag +from .helpers import get_env +from .helpers import get_load_dotenv + +try: + import dotenv +except ImportError: + dotenv = None + +try: + import ssl +except ImportError: + ssl = None # type: ignore + + +class NoAppException(click.UsageError): + """Raised if an application cannot be found or loaded.""" + + +def find_best_app(script_info, module): + """Given a module instance this tries to find the best possible + application in the module or raises an exception. + """ + from . import Flask + + # Search for the most common names first. + for attr_name in ("app", "application"): + app = getattr(module, attr_name, None) + + if isinstance(app, Flask): + return app + + # Otherwise find the only object that is a Flask instance. + matches = [v for v in module.__dict__.values() if isinstance(v, Flask)] + + if len(matches) == 1: + return matches[0] + elif len(matches) > 1: + raise NoAppException( + "Detected multiple Flask applications in module" + f" {module.__name__!r}. Use 'FLASK_APP={module.__name__}:name'" + f" to specify the correct one." + ) + + # Search for app factory functions. + for attr_name in ("create_app", "make_app"): + app_factory = getattr(module, attr_name, None) + + if inspect.isfunction(app_factory): + try: + app = call_factory(script_info, app_factory) + + if isinstance(app, Flask): + return app + except TypeError as e: + if not _called_with_wrong_args(app_factory): + raise + + raise NoAppException( + f"Detected factory {attr_name!r} in module {module.__name__!r}," + " but could not call it without arguments. Use" + f" \"FLASK_APP='{module.__name__}:{attr_name}(args)'\"" + " to specify arguments." + ) from e + + raise NoAppException( + "Failed to find Flask application or factory in module" + f" {module.__name__!r}. Use 'FLASK_APP={module.__name__}:name'" + " to specify one." + ) + + +def call_factory(script_info, app_factory, args=None, kwargs=None): + """Takes an app factory, a ``script_info` object and optionally a tuple + of arguments. Checks for the existence of a script_info argument and calls + the app_factory depending on that and the arguments provided. + """ + sig = inspect.signature(app_factory) + args = [] if args is None else args + kwargs = {} if kwargs is None else kwargs + + if "script_info" in sig.parameters: + warnings.warn( + "The 'script_info' argument is deprecated and will not be" + " passed to the app factory function in Flask 2.1.", + DeprecationWarning, + ) + kwargs["script_info"] = script_info + + if not args and len(sig.parameters) == 1: + first_parameter = next(iter(sig.parameters.values())) + + if ( + first_parameter.default is inspect.Parameter.empty + # **kwargs is reported as an empty default, ignore it + and first_parameter.kind is not inspect.Parameter.VAR_KEYWORD + ): + warnings.warn( + "Script info is deprecated and will not be passed as the" + " single argument to the app factory function in Flask" + " 2.1.", + DeprecationWarning, + ) + args.append(script_info) + + return app_factory(*args, **kwargs) + + +def _called_with_wrong_args(f): + """Check whether calling a function raised a ``TypeError`` because + the call failed or because something in the factory raised the + error. + + :param f: The function that was called. + :return: ``True`` if the call failed. + """ + tb = sys.exc_info()[2] + + try: + while tb is not None: + if tb.tb_frame.f_code is f.__code__: + # In the function, it was called successfully. + return False + + tb = tb.tb_next + + # Didn't reach the function. + return True + finally: + # Delete tb to break a circular reference. + # https://docs.python.org/2/library/sys.html#sys.exc_info + del tb + + +def find_app_by_string(script_info, module, app_name): + """Check if the given string is a variable name or a function. Call + a function to get the app instance, or return the variable directly. + """ + from . import Flask + + # Parse app_name as a single expression to determine if it's a valid + # attribute name or function call. + try: + expr = ast.parse(app_name.strip(), mode="eval").body + except SyntaxError: + raise NoAppException( + f"Failed to parse {app_name!r} as an attribute name or function call." + ) from None + + if isinstance(expr, ast.Name): + name = expr.id + args = kwargs = None + elif isinstance(expr, ast.Call): + # Ensure the function name is an attribute name only. + if not isinstance(expr.func, ast.Name): + raise NoAppException( + f"Function reference must be a simple name: {app_name!r}." + ) + + name = expr.func.id + + # Parse the positional and keyword arguments as literals. + try: + args = [ast.literal_eval(arg) for arg in expr.args] + kwargs = {kw.arg: ast.literal_eval(kw.value) for kw in expr.keywords} + except ValueError: + # literal_eval gives cryptic error messages, show a generic + # message with the full expression instead. + raise NoAppException( + f"Failed to parse arguments as literal values: {app_name!r}." + ) from None + else: + raise NoAppException( + f"Failed to parse {app_name!r} as an attribute name or function call." + ) + + try: + attr = getattr(module, name) + except AttributeError as e: + raise NoAppException( + f"Failed to find attribute {name!r} in {module.__name__!r}." + ) from e + + # If the attribute is a function, call it with any args and kwargs + # to get the real application. + if inspect.isfunction(attr): + try: + app = call_factory(script_info, attr, args, kwargs) + except TypeError as e: + if not _called_with_wrong_args(attr): + raise + + raise NoAppException( + f"The factory {app_name!r} in module" + f" {module.__name__!r} could not be called with the" + " specified arguments." + ) from e + else: + app = attr + + if isinstance(app, Flask): + return app + + raise NoAppException( + "A valid Flask application was not obtained from" + f" '{module.__name__}:{app_name}'." + ) + + +def prepare_import(path): + """Given a filename this will try to calculate the python path, add it + to the search path and return the actual module name that is expected. + """ + path = os.path.realpath(path) + + fname, ext = os.path.splitext(path) + if ext == ".py": + path = fname + + if os.path.basename(path) == "__init__": + path = os.path.dirname(path) + + module_name = [] + + # move up until outside package structure (no __init__.py) + while True: + path, name = os.path.split(path) + module_name.append(name) + + if not os.path.exists(os.path.join(path, "__init__.py")): + break + + if sys.path[0] != path: + sys.path.insert(0, path) + + return ".".join(module_name[::-1]) + + +def locate_app(script_info, module_name, app_name, raise_if_not_found=True): + __traceback_hide__ = True # noqa: F841 + + try: + __import__(module_name) + except ImportError as e: + # Reraise the ImportError if it occurred within the imported module. + # Determine this by checking whether the trace has a depth > 1. + if sys.exc_info()[2].tb_next: + raise NoAppException( + f"While importing {module_name!r}, an ImportError was raised." + ) from e + elif raise_if_not_found: + raise NoAppException(f"Could not import {module_name!r}.") from e + else: + return + + module = sys.modules[module_name] + + if app_name is None: + return find_best_app(script_info, module) + else: + return find_app_by_string(script_info, module, app_name) + + +def get_version(ctx, param, value): + if not value or ctx.resilient_parsing: + return + + import werkzeug + from . import __version__ + + click.echo( + f"Python {platform.python_version()}\n" + f"Flask {__version__}\n" + f"Werkzeug {werkzeug.__version__}", + color=ctx.color, + ) + ctx.exit() + + +version_option = click.Option( + ["--version"], + help="Show the flask version", + expose_value=False, + callback=get_version, + is_flag=True, + is_eager=True, +) + + +class DispatchingApp: + """Special application that dispatches to a Flask application which + is imported by name in a background thread. If an error happens + it is recorded and shown as part of the WSGI handling which in case + of the Werkzeug debugger means that it shows up in the browser. + """ + + def __init__(self, loader, use_eager_loading=None): + self.loader = loader + self._app = None + self._lock = Lock() + self._bg_loading_exc = None + + if use_eager_loading is None: + use_eager_loading = os.environ.get("WERKZEUG_RUN_MAIN") != "true" + + if use_eager_loading: + self._load_unlocked() + else: + self._load_in_background() + + def _load_in_background(self): + def _load_app(): + __traceback_hide__ = True # noqa: F841 + with self._lock: + try: + self._load_unlocked() + except Exception as e: + self._bg_loading_exc = e + + t = Thread(target=_load_app, args=()) + t.start() + + def _flush_bg_loading_exception(self): + __traceback_hide__ = True # noqa: F841 + exc = self._bg_loading_exc + + if exc is not None: + self._bg_loading_exc = None + raise exc + + def _load_unlocked(self): + __traceback_hide__ = True # noqa: F841 + self._app = rv = self.loader() + self._bg_loading_exc = None + return rv + + def __call__(self, environ, start_response): + __traceback_hide__ = True # noqa: F841 + if self._app is not None: + return self._app(environ, start_response) + self._flush_bg_loading_exception() + with self._lock: + if self._app is not None: + rv = self._app + else: + rv = self._load_unlocked() + return rv(environ, start_response) + + +class ScriptInfo: + """Helper object to deal with Flask applications. This is usually not + necessary to interface with as it's used internally in the dispatching + to click. In future versions of Flask this object will most likely play + a bigger role. Typically it's created automatically by the + :class:`FlaskGroup` but you can also manually create it and pass it + onwards as click object. + """ + + def __init__(self, app_import_path=None, create_app=None, set_debug_flag=True): + #: Optionally the import path for the Flask application. + self.app_import_path = app_import_path or os.environ.get("FLASK_APP") + #: Optionally a function that is passed the script info to create + #: the instance of the application. + self.create_app = create_app + #: A dictionary with arbitrary data that can be associated with + #: this script info. + self.data = {} + self.set_debug_flag = set_debug_flag + self._loaded_app = None + + def load_app(self): + """Loads the Flask app (if not yet loaded) and returns it. Calling + this multiple times will just result in the already loaded app to + be returned. + """ + __traceback_hide__ = True # noqa: F841 + + if self._loaded_app is not None: + return self._loaded_app + + if self.create_app is not None: + app = call_factory(self, self.create_app) + else: + if self.app_import_path: + path, name = ( + re.split(r":(?![\\/])", self.app_import_path, 1) + [None] + )[:2] + import_name = prepare_import(path) + app = locate_app(self, import_name, name) + else: + for path in ("wsgi.py", "app.py"): + import_name = prepare_import(path) + app = locate_app(self, import_name, None, raise_if_not_found=False) + + if app: + break + + if not app: + raise NoAppException( + "Could not locate a Flask application. You did not provide " + 'the "FLASK_APP" environment variable, and a "wsgi.py" or ' + '"app.py" module was not found in the current directory.' + ) + + if self.set_debug_flag: + # Update the app's debug flag through the descriptor so that + # other values repopulate as well. + app.debug = get_debug_flag() + + self._loaded_app = app + return app + + +pass_script_info = click.make_pass_decorator(ScriptInfo, ensure=True) + + +def with_appcontext(f): + """Wraps a callback so that it's guaranteed to be executed with the + script's application context. If callbacks are registered directly + to the ``app.cli`` object then they are wrapped with this function + by default unless it's disabled. + """ + + @click.pass_context + def decorator(__ctx, *args, **kwargs): + with __ctx.ensure_object(ScriptInfo).load_app().app_context(): + return __ctx.invoke(f, *args, **kwargs) + + return update_wrapper(decorator, f) + + +class AppGroup(click.Group): + """This works similar to a regular click :class:`~click.Group` but it + changes the behavior of the :meth:`command` decorator so that it + automatically wraps the functions in :func:`with_appcontext`. + + Not to be confused with :class:`FlaskGroup`. + """ + + def command(self, *args, **kwargs): + """This works exactly like the method of the same name on a regular + :class:`click.Group` but it wraps callbacks in :func:`with_appcontext` + unless it's disabled by passing ``with_appcontext=False``. + """ + wrap_for_ctx = kwargs.pop("with_appcontext", True) + + def decorator(f): + if wrap_for_ctx: + f = with_appcontext(f) + return click.Group.command(self, *args, **kwargs)(f) + + return decorator + + def group(self, *args, **kwargs): + """This works exactly like the method of the same name on a regular + :class:`click.Group` but it defaults the group class to + :class:`AppGroup`. + """ + kwargs.setdefault("cls", AppGroup) + return click.Group.group(self, *args, **kwargs) + + +class FlaskGroup(AppGroup): + """Special subclass of the :class:`AppGroup` group that supports + loading more commands from the configured Flask app. Normally a + developer does not have to interface with this class but there are + some very advanced use cases for which it makes sense to create an + instance of this. see :ref:`custom-scripts`. + + :param add_default_commands: if this is True then the default run and + shell commands will be added. + :param add_version_option: adds the ``--version`` option. + :param create_app: an optional callback that is passed the script info and + returns the loaded app. + :param load_dotenv: Load the nearest :file:`.env` and :file:`.flaskenv` + files to set environment variables. Will also change the working + directory to the directory containing the first file found. + :param set_debug_flag: Set the app's debug flag based on the active + environment + + .. versionchanged:: 1.0 + If installed, python-dotenv will be used to load environment variables + from :file:`.env` and :file:`.flaskenv` files. + """ + + def __init__( + self, + add_default_commands=True, + create_app=None, + add_version_option=True, + load_dotenv=True, + set_debug_flag=True, + **extra, + ): + params = list(extra.pop("params", None) or ()) + + if add_version_option: + params.append(version_option) + + AppGroup.__init__(self, params=params, **extra) + self.create_app = create_app + self.load_dotenv = load_dotenv + self.set_debug_flag = set_debug_flag + + if add_default_commands: + self.add_command(run_command) + self.add_command(shell_command) + self.add_command(routes_command) + + self._loaded_plugin_commands = False + + def _load_plugin_commands(self): + if self._loaded_plugin_commands: + return + try: + import pkg_resources + except ImportError: + self._loaded_plugin_commands = True + return + + for ep in pkg_resources.iter_entry_points("flask.commands"): + self.add_command(ep.load(), ep.name) + self._loaded_plugin_commands = True + + def get_command(self, ctx, name): + self._load_plugin_commands() + # Look up built-in and plugin commands, which should be + # available even if the app fails to load. + rv = super().get_command(ctx, name) + + if rv is not None: + return rv + + info = ctx.ensure_object(ScriptInfo) + + # Look up commands provided by the app, showing an error and + # continuing if the app couldn't be loaded. + try: + return info.load_app().cli.get_command(ctx, name) + except NoAppException as e: + click.secho(f"Error: {e.format_message()}\n", err=True, fg="red") + + def list_commands(self, ctx): + self._load_plugin_commands() + # Start with the built-in and plugin commands. + rv = set(super().list_commands(ctx)) + info = ctx.ensure_object(ScriptInfo) + + # Add commands provided by the app, showing an error and + # continuing if the app couldn't be loaded. + try: + rv.update(info.load_app().cli.list_commands(ctx)) + except NoAppException as e: + # When an app couldn't be loaded, show the error message + # without the traceback. + click.secho(f"Error: {e.format_message()}\n", err=True, fg="red") + except Exception: + # When any other errors occurred during loading, show the + # full traceback. + click.secho(f"{traceback.format_exc()}\n", err=True, fg="red") + + return sorted(rv) + + def main(self, *args, **kwargs): + # Set a global flag that indicates that we were invoked from the + # command line interface. This is detected by Flask.run to make the + # call into a no-op. This is necessary to avoid ugly errors when the + # script that is loaded here also attempts to start a server. + os.environ["FLASK_RUN_FROM_CLI"] = "true" + + if get_load_dotenv(self.load_dotenv): + load_dotenv() + + obj = kwargs.get("obj") + + if obj is None: + obj = ScriptInfo( + create_app=self.create_app, set_debug_flag=self.set_debug_flag + ) + + kwargs["obj"] = obj + kwargs.setdefault("auto_envvar_prefix", "FLASK") + return super().main(*args, **kwargs) + + +def _path_is_ancestor(path, other): + """Take ``other`` and remove the length of ``path`` from it. Then join it + to ``path``. If it is the original value, ``path`` is an ancestor of + ``other``.""" + return os.path.join(path, other[len(path) :].lstrip(os.sep)) == other + + +def load_dotenv(path=None): + """Load "dotenv" files in order of precedence to set environment variables. + + If an env var is already set it is not overwritten, so earlier files in the + list are preferred over later files. + + This is a no-op if `python-dotenv`_ is not installed. + + .. _python-dotenv: https://github.com/theskumar/python-dotenv#readme + + :param path: Load the file at this location instead of searching. + :return: ``True`` if a file was loaded. + + .. versionchanged:: 1.1.0 + Returns ``False`` when python-dotenv is not installed, or when + the given path isn't a file. + + .. versionchanged:: 2.0 + When loading the env files, set the default encoding to UTF-8. + + .. versionadded:: 1.0 + """ + if dotenv is None: + if path or os.path.isfile(".env") or os.path.isfile(".flaskenv"): + click.secho( + " * Tip: There are .env or .flaskenv files present." + ' Do "pip install python-dotenv" to use them.', + fg="yellow", + err=True, + ) + + return False + + # if the given path specifies the actual file then return True, + # else False + if path is not None: + if os.path.isfile(path): + return dotenv.load_dotenv(path, encoding="utf-8") + + return False + + new_dir = None + + for name in (".env", ".flaskenv"): + path = dotenv.find_dotenv(name, usecwd=True) + + if not path: + continue + + if new_dir is None: + new_dir = os.path.dirname(path) + + dotenv.load_dotenv(path, encoding="utf-8") + + return new_dir is not None # at least one file was located and loaded + + +def show_server_banner(env, debug, app_import_path, eager_loading): + """Show extra startup messages the first time the server is run, + ignoring the reloader. + """ + if os.environ.get("WERKZEUG_RUN_MAIN") == "true": + return + + if app_import_path is not None: + message = f" * Serving Flask app {app_import_path!r}" + + if not eager_loading: + message += " (lazy loading)" + + click.echo(message) + + click.echo(f" * Environment: {env}") + + if env == "production": + click.secho( + " WARNING: This is a development server. Do not use it in" + " a production deployment.", + fg="red", + ) + click.secho(" Use a production WSGI server instead.", dim=True) + + if debug is not None: + click.echo(f" * Debug mode: {'on' if debug else 'off'}") + + +class CertParamType(click.ParamType): + """Click option type for the ``--cert`` option. Allows either an + existing file, the string ``'adhoc'``, or an import for a + :class:`~ssl.SSLContext` object. + """ + + name = "path" + + def __init__(self): + self.path_type = click.Path(exists=True, dir_okay=False, resolve_path=True) + + def convert(self, value, param, ctx): + if ssl is None: + raise click.BadParameter( + 'Using "--cert" requires Python to be compiled with SSL support.', + ctx, + param, + ) + + try: + return self.path_type(value, param, ctx) + except click.BadParameter: + value = click.STRING(value, param, ctx).lower() + + if value == "adhoc": + try: + import cryptography # noqa: F401 + except ImportError: + raise click.BadParameter( + "Using ad-hoc certificates requires the cryptography library.", + ctx, + param, + ) from None + + return value + + obj = import_string(value, silent=True) + + if isinstance(obj, ssl.SSLContext): + return obj + + raise + + +def _validate_key(ctx, param, value): + """The ``--key`` option must be specified when ``--cert`` is a file. + Modifies the ``cert`` param to be a ``(cert, key)`` pair if needed. + """ + cert = ctx.params.get("cert") + is_adhoc = cert == "adhoc" + is_context = ssl and isinstance(cert, ssl.SSLContext) + + if value is not None: + if is_adhoc: + raise click.BadParameter( + 'When "--cert" is "adhoc", "--key" is not used.', ctx, param + ) + + if is_context: + raise click.BadParameter( + 'When "--cert" is an SSLContext object, "--key is not used.', ctx, param + ) + + if not cert: + raise click.BadParameter('"--cert" must also be specified.', ctx, param) + + ctx.params["cert"] = cert, value + + else: + if cert and not (is_adhoc or is_context): + raise click.BadParameter('Required when using "--cert".', ctx, param) + + return value + + +class SeparatedPathType(click.Path): + """Click option type that accepts a list of values separated by the + OS's path separator (``:``, ``;`` on Windows). Each value is + validated as a :class:`click.Path` type. + """ + + def convert(self, value, param, ctx): + items = self.split_envvar_value(value) + super_convert = super().convert + return [super_convert(item, param, ctx) for item in items] + + +@click.command("run", short_help="Run a development server.") +@click.option("--host", "-h", default="127.0.0.1", help="The interface to bind to.") +@click.option("--port", "-p", default=5000, help="The port to bind to.") +@click.option( + "--cert", type=CertParamType(), help="Specify a certificate file to use HTTPS." +) +@click.option( + "--key", + type=click.Path(exists=True, dir_okay=False, resolve_path=True), + callback=_validate_key, + expose_value=False, + help="The key file to use when specifying a certificate.", +) +@click.option( + "--reload/--no-reload", + default=None, + help="Enable or disable the reloader. By default the reloader " + "is active if debug is enabled.", +) +@click.option( + "--debugger/--no-debugger", + default=None, + help="Enable or disable the debugger. By default the debugger " + "is active if debug is enabled.", +) +@click.option( + "--eager-loading/--lazy-loading", + default=None, + help="Enable or disable eager loading. By default eager " + "loading is enabled if the reloader is disabled.", +) +@click.option( + "--with-threads/--without-threads", + default=True, + help="Enable or disable multithreading.", +) +@click.option( + "--extra-files", + default=None, + type=SeparatedPathType(), + help=( + "Extra files that trigger a reload on change. Multiple paths" + f" are separated by {os.path.pathsep!r}." + ), +) +@pass_script_info +def run_command( + info, host, port, reload, debugger, eager_loading, with_threads, cert, extra_files +): + """Run a local development server. + + This server is for development purposes only. It does not provide + the stability, security, or performance of production WSGI servers. + + The reloader and debugger are enabled by default if + FLASK_ENV=development or FLASK_DEBUG=1. + """ + debug = get_debug_flag() + + if reload is None: + reload = debug + + if debugger is None: + debugger = debug + + show_server_banner(get_env(), debug, info.app_import_path, eager_loading) + app = DispatchingApp(info.load_app, use_eager_loading=eager_loading) + + from werkzeug.serving import run_simple + + run_simple( + host, + port, + app, + use_reloader=reload, + use_debugger=debugger, + threaded=with_threads, + ssl_context=cert, + extra_files=extra_files, + ) + + +@click.command("shell", short_help="Run a shell in the app context.") +@with_appcontext +def shell_command() -> None: + """Run an interactive Python shell in the context of a given + Flask application. The application will populate the default + namespace of this shell according to its configuration. + + This is useful for executing small snippets of management code + without having to manually configure the application. + """ + import code + from .globals import _app_ctx_stack + + app = _app_ctx_stack.top.app + banner = ( + f"Python {sys.version} on {sys.platform}\n" + f"App: {app.import_name} [{app.env}]\n" + f"Instance: {app.instance_path}" + ) + ctx: dict = {} + + # Support the regular Python interpreter startup script if someone + # is using it. + startup = os.environ.get("PYTHONSTARTUP") + if startup and os.path.isfile(startup): + with open(startup) as f: + eval(compile(f.read(), startup, "exec"), ctx) + + ctx.update(app.make_shell_context()) + + # Site, customize, or startup script can set a hook to call when + # entering interactive mode. The default one sets up readline with + # tab and history completion. + interactive_hook = getattr(sys, "__interactivehook__", None) + + if interactive_hook is not None: + try: + import readline + from rlcompleter import Completer + except ImportError: + pass + else: + # rlcompleter uses __main__.__dict__ by default, which is + # flask.__main__. Use the shell context instead. + readline.set_completer(Completer(ctx).complete) + + interactive_hook() + + code.interact(banner=banner, local=ctx) + + +@click.command("routes", short_help="Show the routes for the app.") +@click.option( + "--sort", + "-s", + type=click.Choice(("endpoint", "methods", "rule", "match")), + default="endpoint", + help=( + 'Method to sort routes by. "match" is the order that Flask will match ' + "routes when dispatching a request." + ), +) +@click.option("--all-methods", is_flag=True, help="Show HEAD and OPTIONS methods.") +@with_appcontext +def routes_command(sort: str, all_methods: bool) -> None: + """Show all registered routes with endpoints and methods.""" + + rules = list(current_app.url_map.iter_rules()) + if not rules: + click.echo("No routes were registered.") + return + + ignored_methods = set(() if all_methods else ("HEAD", "OPTIONS")) + + if sort in ("endpoint", "rule"): + rules = sorted(rules, key=attrgetter(sort)) + elif sort == "methods": + rules = sorted(rules, key=lambda rule: sorted(rule.methods)) # type: ignore + + rule_methods = [ + ", ".join(sorted(rule.methods - ignored_methods)) # type: ignore + for rule in rules + ] + + headers = ("Endpoint", "Methods", "Rule") + widths = ( + max(len(rule.endpoint) for rule in rules), + max(len(methods) for methods in rule_methods), + max(len(rule.rule) for rule in rules), + ) + widths = [max(len(h), w) for h, w in zip(headers, widths)] + row = "{{0:<{0}}} {{1:<{1}}} {{2:<{2}}}".format(*widths) + + click.echo(row.format(*headers).strip()) + click.echo(row.format(*("-" * width for width in widths))) + + for rule, methods in zip(rules, rule_methods): + click.echo(row.format(rule.endpoint, methods, rule.rule).rstrip()) + + +cli = FlaskGroup( + help="""\ +A general utility script for Flask applications. + +Provides commands from Flask, extensions, and the application. Loads the +application defined in the FLASK_APP environment variable, or from a wsgi.py +file. Setting the FLASK_ENV environment variable to 'development' will enable +debug mode. + +\b + {prefix}{cmd} FLASK_APP=hello.py + {prefix}{cmd} FLASK_ENV=development + {prefix}flask run +""".format( + cmd="export" if os.name == "posix" else "set", + prefix="$ " if os.name == "posix" else "> ", + ) +) + + +def main() -> None: + if int(click.__version__[0]) < 8: + warnings.warn( + "Using the `flask` cli with Click 7 is deprecated and" + " will not be supported starting with Flask 2.1." + " Please upgrade to Click 8 as soon as possible.", + DeprecationWarning, + ) + # TODO omit sys.argv once https://github.com/pallets/click/issues/536 is fixed + cli.main(args=sys.argv[1:]) + + +if __name__ == "__main__": + main() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/config.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/config.py new file mode 100644 index 00000000..ca769022 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/config.py @@ -0,0 +1,295 @@ +import errno +import os +import types +import typing as t + +from werkzeug.utils import import_string + + +class ConfigAttribute: + """Makes an attribute forward to the config""" + + def __init__(self, name: str, get_converter: t.Optional[t.Callable] = None) -> None: + self.__name__ = name + self.get_converter = get_converter + + def __get__(self, obj: t.Any, owner: t.Any = None) -> t.Any: + if obj is None: + return self + rv = obj.config[self.__name__] + if self.get_converter is not None: + rv = self.get_converter(rv) + return rv + + def __set__(self, obj: t.Any, value: t.Any) -> None: + obj.config[self.__name__] = value + + +class Config(dict): + """Works exactly like a dict but provides ways to fill it from files + or special dictionaries. There are two common patterns to populate the + config. + + Either you can fill the config from a config file:: + + app.config.from_pyfile('yourconfig.cfg') + + Or alternatively you can define the configuration options in the + module that calls :meth:`from_object` or provide an import path to + a module that should be loaded. It is also possible to tell it to + use the same module and with that provide the configuration values + just before the call:: + + DEBUG = True + SECRET_KEY = 'development key' + app.config.from_object(__name__) + + In both cases (loading from any Python file or loading from modules), + only uppercase keys are added to the config. This makes it possible to use + lowercase values in the config file for temporary values that are not added + to the config or to define the config keys in the same file that implements + the application. + + Probably the most interesting way to load configurations is from an + environment variable pointing to a file:: + + app.config.from_envvar('YOURAPPLICATION_SETTINGS') + + In this case before launching the application you have to set this + environment variable to the file you want to use. On Linux and OS X + use the export statement:: + + export YOURAPPLICATION_SETTINGS='/path/to/config/file' + + On windows use `set` instead. + + :param root_path: path to which files are read relative from. When the + config object is created by the application, this is + the application's :attr:`~flask.Flask.root_path`. + :param defaults: an optional dictionary of default values + """ + + def __init__(self, root_path: str, defaults: t.Optional[dict] = None) -> None: + dict.__init__(self, defaults or {}) + self.root_path = root_path + + def from_envvar(self, variable_name: str, silent: bool = False) -> bool: + """Loads a configuration from an environment variable pointing to + a configuration file. This is basically just a shortcut with nicer + error messages for this line of code:: + + app.config.from_pyfile(os.environ['YOURAPPLICATION_SETTINGS']) + + :param variable_name: name of the environment variable + :param silent: set to ``True`` if you want silent failure for missing + files. + :return: ``True`` if the file was loaded successfully. + """ + rv = os.environ.get(variable_name) + if not rv: + if silent: + return False + raise RuntimeError( + f"The environment variable {variable_name!r} is not set" + " and as such configuration could not be loaded. Set" + " this variable and make it point to a configuration" + " file" + ) + return self.from_pyfile(rv, silent=silent) + + def from_pyfile(self, filename: str, silent: bool = False) -> bool: + """Updates the values in the config from a Python file. This function + behaves as if the file was imported as module with the + :meth:`from_object` function. + + :param filename: the filename of the config. This can either be an + absolute filename or a filename relative to the + root path. + :param silent: set to ``True`` if you want silent failure for missing + files. + :return: ``True`` if the file was loaded successfully. + + .. versionadded:: 0.7 + `silent` parameter. + """ + filename = os.path.join(self.root_path, filename) + d = types.ModuleType("config") + d.__file__ = filename + try: + with open(filename, mode="rb") as config_file: + exec(compile(config_file.read(), filename, "exec"), d.__dict__) + except OSError as e: + if silent and e.errno in (errno.ENOENT, errno.EISDIR, errno.ENOTDIR): + return False + e.strerror = f"Unable to load configuration file ({e.strerror})" + raise + self.from_object(d) + return True + + def from_object(self, obj: t.Union[object, str]) -> None: + """Updates the values from the given object. An object can be of one + of the following two types: + + - a string: in this case the object with that name will be imported + - an actual object reference: that object is used directly + + Objects are usually either modules or classes. :meth:`from_object` + loads only the uppercase attributes of the module/class. A ``dict`` + object will not work with :meth:`from_object` because the keys of a + ``dict`` are not attributes of the ``dict`` class. + + Example of module-based configuration:: + + app.config.from_object('yourapplication.default_config') + from yourapplication import default_config + app.config.from_object(default_config) + + Nothing is done to the object before loading. If the object is a + class and has ``@property`` attributes, it needs to be + instantiated before being passed to this method. + + You should not use this function to load the actual configuration but + rather configuration defaults. The actual config should be loaded + with :meth:`from_pyfile` and ideally from a location not within the + package because the package might be installed system wide. + + See :ref:`config-dev-prod` for an example of class-based configuration + using :meth:`from_object`. + + :param obj: an import name or object + """ + if isinstance(obj, str): + obj = import_string(obj) + for key in dir(obj): + if key.isupper(): + self[key] = getattr(obj, key) + + def from_file( + self, + filename: str, + load: t.Callable[[t.IO[t.Any]], t.Mapping], + silent: bool = False, + ) -> bool: + """Update the values in the config from a file that is loaded + using the ``load`` parameter. The loaded data is passed to the + :meth:`from_mapping` method. + + .. code-block:: python + + import toml + app.config.from_file("config.toml", load=toml.load) + + :param filename: The path to the data file. This can be an + absolute path or relative to the config root path. + :param load: A callable that takes a file handle and returns a + mapping of loaded data from the file. + :type load: ``Callable[[Reader], Mapping]`` where ``Reader`` + implements a ``read`` method. + :param silent: Ignore the file if it doesn't exist. + :return: ``True`` if the file was loaded successfully. + + .. versionadded:: 2.0 + """ + filename = os.path.join(self.root_path, filename) + + try: + with open(filename) as f: + obj = load(f) + except OSError as e: + if silent and e.errno in (errno.ENOENT, errno.EISDIR): + return False + + e.strerror = f"Unable to load configuration file ({e.strerror})" + raise + + return self.from_mapping(obj) + + def from_json(self, filename: str, silent: bool = False) -> bool: + """Update the values in the config from a JSON file. The loaded + data is passed to the :meth:`from_mapping` method. + + :param filename: The path to the JSON file. This can be an + absolute path or relative to the config root path. + :param silent: Ignore the file if it doesn't exist. + :return: ``True`` if the file was loaded successfully. + + .. deprecated:: 2.0.0 + Will be removed in Flask 2.1. Use :meth:`from_file` instead. + This was removed early in 2.0.0, was added back in 2.0.1. + + .. versionadded:: 0.11 + """ + import warnings + from . import json + + warnings.warn( + "'from_json' is deprecated and will be removed in Flask" + " 2.1. Use 'from_file(path, json.load)' instead.", + DeprecationWarning, + stacklevel=2, + ) + return self.from_file(filename, json.load, silent=silent) + + def from_mapping( + self, mapping: t.Optional[t.Mapping[str, t.Any]] = None, **kwargs: t.Any + ) -> bool: + """Updates the config like :meth:`update` ignoring items with non-upper + keys. + :return: Always returns ``True``. + + .. versionadded:: 0.11 + """ + mappings: t.Dict[str, t.Any] = {} + if mapping is not None: + mappings.update(mapping) + mappings.update(kwargs) + for key, value in mappings.items(): + if key.isupper(): + self[key] = value + return True + + def get_namespace( + self, namespace: str, lowercase: bool = True, trim_namespace: bool = True + ) -> t.Dict[str, t.Any]: + """Returns a dictionary containing a subset of configuration options + that match the specified namespace/prefix. Example usage:: + + app.config['IMAGE_STORE_TYPE'] = 'fs' + app.config['IMAGE_STORE_PATH'] = '/var/app/images' + app.config['IMAGE_STORE_BASE_URL'] = 'http://img.website.com' + image_store_config = app.config.get_namespace('IMAGE_STORE_') + + The resulting dictionary `image_store_config` would look like:: + + { + 'type': 'fs', + 'path': '/var/app/images', + 'base_url': 'http://img.website.com' + } + + This is often useful when configuration options map directly to + keyword arguments in functions or class constructors. + + :param namespace: a configuration namespace + :param lowercase: a flag indicating if the keys of the resulting + dictionary should be lowercase + :param trim_namespace: a flag indicating if the keys of the resulting + dictionary should not include the namespace + + .. versionadded:: 0.11 + """ + rv = {} + for k, v in self.items(): + if not k.startswith(namespace): + continue + if trim_namespace: + key = k[len(namespace) :] + else: + key = k + if lowercase: + key = key.lower() + rv[key] = v + return rv + + def __repr__(self) -> str: + return f"<{type(self).__name__} {dict.__repr__(self)}>" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/ctx.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/ctx.py new file mode 100644 index 00000000..5c064635 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/ctx.py @@ -0,0 +1,480 @@ +import sys +import typing as t +from functools import update_wrapper +from types import TracebackType + +from werkzeug.exceptions import HTTPException + +from .globals import _app_ctx_stack +from .globals import _request_ctx_stack +from .signals import appcontext_popped +from .signals import appcontext_pushed +from .typing import AfterRequestCallable + +if t.TYPE_CHECKING: + from .app import Flask + from .sessions import SessionMixin + from .wrappers import Request + + +# a singleton sentinel value for parameter defaults +_sentinel = object() + + +class _AppCtxGlobals: + """A plain object. Used as a namespace for storing data during an + application context. + + Creating an app context automatically creates this object, which is + made available as the :data:`g` proxy. + + .. describe:: 'key' in g + + Check whether an attribute is present. + + .. versionadded:: 0.10 + + .. describe:: iter(g) + + Return an iterator over the attribute names. + + .. versionadded:: 0.10 + """ + + # Define attr methods to let mypy know this is a namespace object + # that has arbitrary attributes. + + def __getattr__(self, name: str) -> t.Any: + try: + return self.__dict__[name] + except KeyError: + raise AttributeError(name) from None + + def __setattr__(self, name: str, value: t.Any) -> None: + self.__dict__[name] = value + + def __delattr__(self, name: str) -> None: + try: + del self.__dict__[name] + except KeyError: + raise AttributeError(name) from None + + def get(self, name: str, default: t.Optional[t.Any] = None) -> t.Any: + """Get an attribute by name, or a default value. Like + :meth:`dict.get`. + + :param name: Name of attribute to get. + :param default: Value to return if the attribute is not present. + + .. versionadded:: 0.10 + """ + return self.__dict__.get(name, default) + + def pop(self, name: str, default: t.Any = _sentinel) -> t.Any: + """Get and remove an attribute by name. Like :meth:`dict.pop`. + + :param name: Name of attribute to pop. + :param default: Value to return if the attribute is not present, + instead of raising a ``KeyError``. + + .. versionadded:: 0.11 + """ + if default is _sentinel: + return self.__dict__.pop(name) + else: + return self.__dict__.pop(name, default) + + def setdefault(self, name: str, default: t.Any = None) -> t.Any: + """Get the value of an attribute if it is present, otherwise + set and return a default value. Like :meth:`dict.setdefault`. + + :param name: Name of attribute to get. + :param default: Value to set and return if the attribute is not + present. + + .. versionadded:: 0.11 + """ + return self.__dict__.setdefault(name, default) + + def __contains__(self, item: str) -> bool: + return item in self.__dict__ + + def __iter__(self) -> t.Iterator[str]: + return iter(self.__dict__) + + def __repr__(self) -> str: + top = _app_ctx_stack.top + if top is not None: + return f"" + return object.__repr__(self) + + +def after_this_request(f: AfterRequestCallable) -> AfterRequestCallable: + """Executes a function after this request. This is useful to modify + response objects. The function is passed the response object and has + to return the same or a new one. + + Example:: + + @app.route('/') + def index(): + @after_this_request + def add_header(response): + response.headers['X-Foo'] = 'Parachute' + return response + return 'Hello World!' + + This is more useful if a function other than the view function wants to + modify a response. For instance think of a decorator that wants to add + some headers without converting the return value into a response object. + + .. versionadded:: 0.9 + """ + _request_ctx_stack.top._after_request_functions.append(f) + return f + + +def copy_current_request_context(f: t.Callable) -> t.Callable: + """A helper function that decorates a function to retain the current + request context. This is useful when working with greenlets. The moment + the function is decorated a copy of the request context is created and + then pushed when the function is called. The current session is also + included in the copied request context. + + Example:: + + import gevent + from flask import copy_current_request_context + + @app.route('/') + def index(): + @copy_current_request_context + def do_some_work(): + # do some work here, it can access flask.request or + # flask.session like you would otherwise in the view function. + ... + gevent.spawn(do_some_work) + return 'Regular response' + + .. versionadded:: 0.10 + """ + top = _request_ctx_stack.top + if top is None: + raise RuntimeError( + "This decorator can only be used at local scopes " + "when a request context is on the stack. For instance within " + "view functions." + ) + reqctx = top.copy() + + def wrapper(*args, **kwargs): + with reqctx: + return f(*args, **kwargs) + + return update_wrapper(wrapper, f) + + +def has_request_context() -> bool: + """If you have code that wants to test if a request context is there or + not this function can be used. For instance, you may want to take advantage + of request information if the request object is available, but fail + silently if it is unavailable. + + :: + + class User(db.Model): + + def __init__(self, username, remote_addr=None): + self.username = username + if remote_addr is None and has_request_context(): + remote_addr = request.remote_addr + self.remote_addr = remote_addr + + Alternatively you can also just test any of the context bound objects + (such as :class:`request` or :class:`g`) for truthness:: + + class User(db.Model): + + def __init__(self, username, remote_addr=None): + self.username = username + if remote_addr is None and request: + remote_addr = request.remote_addr + self.remote_addr = remote_addr + + .. versionadded:: 0.7 + """ + return _request_ctx_stack.top is not None + + +def has_app_context() -> bool: + """Works like :func:`has_request_context` but for the application + context. You can also just do a boolean check on the + :data:`current_app` object instead. + + .. versionadded:: 0.9 + """ + return _app_ctx_stack.top is not None + + +class AppContext: + """The application context binds an application object implicitly + to the current thread or greenlet, similar to how the + :class:`RequestContext` binds request information. The application + context is also implicitly created if a request context is created + but the application is not on top of the individual application + context. + """ + + def __init__(self, app: "Flask") -> None: + self.app = app + self.url_adapter = app.create_url_adapter(None) + self.g = app.app_ctx_globals_class() + + # Like request context, app contexts can be pushed multiple times + # but there a basic "refcount" is enough to track them. + self._refcnt = 0 + + def push(self) -> None: + """Binds the app context to the current context.""" + self._refcnt += 1 + _app_ctx_stack.push(self) + appcontext_pushed.send(self.app) + + def pop(self, exc: t.Optional[BaseException] = _sentinel) -> None: # type: ignore + """Pops the app context.""" + try: + self._refcnt -= 1 + if self._refcnt <= 0: + if exc is _sentinel: + exc = sys.exc_info()[1] + self.app.do_teardown_appcontext(exc) + finally: + rv = _app_ctx_stack.pop() + assert rv is self, f"Popped wrong app context. ({rv!r} instead of {self!r})" + appcontext_popped.send(self.app) + + def __enter__(self) -> "AppContext": + self.push() + return self + + def __exit__( + self, exc_type: type, exc_value: BaseException, tb: TracebackType + ) -> None: + self.pop(exc_value) + + +class RequestContext: + """The request context contains all request relevant information. It is + created at the beginning of the request and pushed to the + `_request_ctx_stack` and removed at the end of it. It will create the + URL adapter and request object for the WSGI environment provided. + + Do not attempt to use this class directly, instead use + :meth:`~flask.Flask.test_request_context` and + :meth:`~flask.Flask.request_context` to create this object. + + When the request context is popped, it will evaluate all the + functions registered on the application for teardown execution + (:meth:`~flask.Flask.teardown_request`). + + The request context is automatically popped at the end of the request + for you. In debug mode the request context is kept around if + exceptions happen so that interactive debuggers have a chance to + introspect the data. With 0.4 this can also be forced for requests + that did not fail and outside of ``DEBUG`` mode. By setting + ``'flask._preserve_context'`` to ``True`` on the WSGI environment the + context will not pop itself at the end of the request. This is used by + the :meth:`~flask.Flask.test_client` for example to implement the + deferred cleanup functionality. + + You might find this helpful for unittests where you need the + information from the context local around for a little longer. Make + sure to properly :meth:`~werkzeug.LocalStack.pop` the stack yourself in + that situation, otherwise your unittests will leak memory. + """ + + def __init__( + self, + app: "Flask", + environ: dict, + request: t.Optional["Request"] = None, + session: t.Optional["SessionMixin"] = None, + ) -> None: + self.app = app + if request is None: + request = app.request_class(environ) + self.request = request + self.url_adapter = None + try: + self.url_adapter = app.create_url_adapter(self.request) + except HTTPException as e: + self.request.routing_exception = e + self.flashes = None + self.session = session + + # Request contexts can be pushed multiple times and interleaved with + # other request contexts. Now only if the last level is popped we + # get rid of them. Additionally if an application context is missing + # one is created implicitly so for each level we add this information + self._implicit_app_ctx_stack: t.List[t.Optional["AppContext"]] = [] + + # indicator if the context was preserved. Next time another context + # is pushed the preserved context is popped. + self.preserved = False + + # remembers the exception for pop if there is one in case the context + # preservation kicks in. + self._preserved_exc = None + + # Functions that should be executed after the request on the response + # object. These will be called before the regular "after_request" + # functions. + self._after_request_functions: t.List[AfterRequestCallable] = [] + + @property + def g(self) -> AppContext: + return _app_ctx_stack.top.g + + @g.setter + def g(self, value: AppContext) -> None: + _app_ctx_stack.top.g = value + + def copy(self) -> "RequestContext": + """Creates a copy of this request context with the same request object. + This can be used to move a request context to a different greenlet. + Because the actual request object is the same this cannot be used to + move a request context to a different thread unless access to the + request object is locked. + + .. versionadded:: 0.10 + + .. versionchanged:: 1.1 + The current session object is used instead of reloading the original + data. This prevents `flask.session` pointing to an out-of-date object. + """ + return self.__class__( + self.app, + environ=self.request.environ, + request=self.request, + session=self.session, + ) + + def match_request(self) -> None: + """Can be overridden by a subclass to hook into the matching + of the request. + """ + try: + result = self.url_adapter.match(return_rule=True) # type: ignore + self.request.url_rule, self.request.view_args = result # type: ignore + except HTTPException as e: + self.request.routing_exception = e + + def push(self) -> None: + """Binds the request context to the current context.""" + # If an exception occurs in debug mode or if context preservation is + # activated under exception situations exactly one context stays + # on the stack. The rationale is that you want to access that + # information under debug situations. However if someone forgets to + # pop that context again we want to make sure that on the next push + # it's invalidated, otherwise we run at risk that something leaks + # memory. This is usually only a problem in test suite since this + # functionality is not active in production environments. + top = _request_ctx_stack.top + if top is not None and top.preserved: + top.pop(top._preserved_exc) + + # Before we push the request context we have to ensure that there + # is an application context. + app_ctx = _app_ctx_stack.top + if app_ctx is None or app_ctx.app != self.app: + app_ctx = self.app.app_context() + app_ctx.push() + self._implicit_app_ctx_stack.append(app_ctx) + else: + self._implicit_app_ctx_stack.append(None) + + _request_ctx_stack.push(self) + + # Open the session at the moment that the request context is available. + # This allows a custom open_session method to use the request context. + # Only open a new session if this is the first time the request was + # pushed, otherwise stream_with_context loses the session. + if self.session is None: + session_interface = self.app.session_interface + self.session = session_interface.open_session(self.app, self.request) + + if self.session is None: + self.session = session_interface.make_null_session(self.app) + + # Match the request URL after loading the session, so that the + # session is available in custom URL converters. + if self.url_adapter is not None: + self.match_request() + + def pop(self, exc: t.Optional[BaseException] = _sentinel) -> None: # type: ignore + """Pops the request context and unbinds it by doing that. This will + also trigger the execution of functions registered by the + :meth:`~flask.Flask.teardown_request` decorator. + + .. versionchanged:: 0.9 + Added the `exc` argument. + """ + app_ctx = self._implicit_app_ctx_stack.pop() + clear_request = False + + try: + if not self._implicit_app_ctx_stack: + self.preserved = False + self._preserved_exc = None + if exc is _sentinel: + exc = sys.exc_info()[1] + self.app.do_teardown_request(exc) + + request_close = getattr(self.request, "close", None) + if request_close is not None: + request_close() + clear_request = True + finally: + rv = _request_ctx_stack.pop() + + # get rid of circular dependencies at the end of the request + # so that we don't require the GC to be active. + if clear_request: + rv.request.environ["werkzeug.request"] = None + + # Get rid of the app as well if necessary. + if app_ctx is not None: + app_ctx.pop(exc) + + assert ( + rv is self + ), f"Popped wrong request context. ({rv!r} instead of {self!r})" + + def auto_pop(self, exc: t.Optional[BaseException]) -> None: + if self.request.environ.get("flask._preserve_context") or ( + exc is not None and self.app.preserve_context_on_exception + ): + self.preserved = True + self._preserved_exc = exc # type: ignore + else: + self.pop(exc) + + def __enter__(self) -> "RequestContext": + self.push() + return self + + def __exit__( + self, exc_type: type, exc_value: BaseException, tb: TracebackType + ) -> None: + # do not pop the request stack if we are in debug mode and an + # exception happened. This will allow the debugger to still + # access the request object in the interactive shell. Furthermore + # the context can be force kept alive for the test client. + # See flask.testing for how this works. + self.auto_pop(exc_value) + + def __repr__(self) -> str: + return ( + f"<{type(self).__name__} {self.request.url!r}" + f" [{self.request.method}] of {self.app.name}>" + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/debughelpers.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/debughelpers.py new file mode 100644 index 00000000..212f7d7e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/debughelpers.py @@ -0,0 +1,172 @@ +import os +import typing as t +from warnings import warn + +from .app import Flask +from .blueprints import Blueprint +from .globals import _request_ctx_stack + + +class UnexpectedUnicodeError(AssertionError, UnicodeError): + """Raised in places where we want some better error reporting for + unexpected unicode or binary data. + """ + + +class DebugFilesKeyError(KeyError, AssertionError): + """Raised from request.files during debugging. The idea is that it can + provide a better error message than just a generic KeyError/BadRequest. + """ + + def __init__(self, request, key): + form_matches = request.form.getlist(key) + buf = [ + f"You tried to access the file {key!r} in the request.files" + " dictionary but it does not exist. The mimetype for the" + f" request is {request.mimetype!r} instead of" + " 'multipart/form-data' which means that no file contents" + " were transmitted. To fix this error you should provide" + ' enctype="multipart/form-data" in your form.' + ] + if form_matches: + names = ", ".join(repr(x) for x in form_matches) + buf.append( + "\n\nThe browser instead transmitted some file names. " + f"This was submitted: {names}" + ) + self.msg = "".join(buf) + + def __str__(self): + return self.msg + + +class FormDataRoutingRedirect(AssertionError): + """This exception is raised by Flask in debug mode if it detects a + redirect caused by the routing system when the request method is not + GET, HEAD or OPTIONS. Reasoning: form data will be dropped. + """ + + def __init__(self, request): + exc = request.routing_exception + buf = [ + f"A request was sent to this URL ({request.url}) but a" + " redirect was issued automatically by the routing system" + f" to {exc.new_url!r}." + ] + + # In case just a slash was appended we can be extra helpful + if f"{request.base_url}/" == exc.new_url.split("?")[0]: + buf.append( + " The URL was defined with a trailing slash so Flask" + " will automatically redirect to the URL with the" + " trailing slash if it was accessed without one." + ) + + buf.append( + " Make sure to directly send your" + f" {request.method}-request to this URL since we can't make" + " browsers or HTTP clients redirect with form data reliably" + " or without user interaction." + ) + buf.append("\n\nNote: this exception is only raised in debug mode") + AssertionError.__init__(self, "".join(buf).encode("utf-8")) + + +def attach_enctype_error_multidict(request): + """Since Flask 0.8 we're monkeypatching the files object in case a + request is detected that does not use multipart form data but the files + object is accessed. + """ + oldcls = request.files.__class__ + + class newcls(oldcls): + def __getitem__(self, key): + try: + return oldcls.__getitem__(self, key) + except KeyError as e: + if key not in request.form: + raise + + raise DebugFilesKeyError(request, key) from e + + newcls.__name__ = oldcls.__name__ + newcls.__module__ = oldcls.__module__ + request.files.__class__ = newcls + + +def _dump_loader_info(loader) -> t.Generator: + yield f"class: {type(loader).__module__}.{type(loader).__name__}" + for key, value in sorted(loader.__dict__.items()): + if key.startswith("_"): + continue + if isinstance(value, (tuple, list)): + if not all(isinstance(x, str) for x in value): + continue + yield f"{key}:" + for item in value: + yield f" - {item}" + continue + elif not isinstance(value, (str, int, float, bool)): + continue + yield f"{key}: {value!r}" + + +def explain_template_loading_attempts(app: Flask, template, attempts) -> None: + """This should help developers understand what failed""" + info = [f"Locating template {template!r}:"] + total_found = 0 + blueprint = None + reqctx = _request_ctx_stack.top + if reqctx is not None and reqctx.request.blueprint is not None: + blueprint = reqctx.request.blueprint + + for idx, (loader, srcobj, triple) in enumerate(attempts): + if isinstance(srcobj, Flask): + src_info = f"application {srcobj.import_name!r}" + elif isinstance(srcobj, Blueprint): + src_info = f"blueprint {srcobj.name!r} ({srcobj.import_name})" + else: + src_info = repr(srcobj) + + info.append(f"{idx + 1:5}: trying loader of {src_info}") + + for line in _dump_loader_info(loader): + info.append(f" {line}") + + if triple is None: + detail = "no match" + else: + detail = f"found ({triple[1] or ''!r})" + total_found += 1 + info.append(f" -> {detail}") + + seems_fishy = False + if total_found == 0: + info.append("Error: the template could not be found.") + seems_fishy = True + elif total_found > 1: + info.append("Warning: multiple loaders returned a match for the template.") + seems_fishy = True + + if blueprint is not None and seems_fishy: + info.append( + " The template was looked up from an endpoint that belongs" + f" to the blueprint {blueprint!r}." + ) + info.append(" Maybe you did not place a template in the right folder?") + info.append(" See https://flask.palletsprojects.com/blueprints/#templates") + + app.logger.info("\n".join(info)) + + +def explain_ignored_app_run() -> None: + if os.environ.get("WERKZEUG_RUN_MAIN") != "true": + warn( + Warning( + "Silently ignoring app.run() because the application is" + " run from the flask command line executable. Consider" + ' putting app.run() behind an if __name__ == "__main__"' + " guard to silence this warning." + ), + stacklevel=3, + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/globals.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/globals.py new file mode 100644 index 00000000..6d91c75e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/globals.py @@ -0,0 +1,59 @@ +import typing as t +from functools import partial + +from werkzeug.local import LocalProxy +from werkzeug.local import LocalStack + +if t.TYPE_CHECKING: + from .app import Flask + from .ctx import _AppCtxGlobals + from .sessions import SessionMixin + from .wrappers import Request + +_request_ctx_err_msg = """\ +Working outside of request context. + +This typically means that you attempted to use functionality that needed +an active HTTP request. Consult the documentation on testing for +information about how to avoid this problem.\ +""" +_app_ctx_err_msg = """\ +Working outside of application context. + +This typically means that you attempted to use functionality that needed +to interface with the current application object in some way. To solve +this, set up an application context with app.app_context(). See the +documentation for more information.\ +""" + + +def _lookup_req_object(name): + top = _request_ctx_stack.top + if top is None: + raise RuntimeError(_request_ctx_err_msg) + return getattr(top, name) + + +def _lookup_app_object(name): + top = _app_ctx_stack.top + if top is None: + raise RuntimeError(_app_ctx_err_msg) + return getattr(top, name) + + +def _find_app(): + top = _app_ctx_stack.top + if top is None: + raise RuntimeError(_app_ctx_err_msg) + return top.app + + +# context locals +_request_ctx_stack = LocalStack() +_app_ctx_stack = LocalStack() +current_app: "Flask" = LocalProxy(_find_app) # type: ignore +request: "Request" = LocalProxy(partial(_lookup_req_object, "request")) # type: ignore +session: "SessionMixin" = LocalProxy( # type: ignore + partial(_lookup_req_object, "session") +) +g: "_AppCtxGlobals" = LocalProxy(partial(_lookup_app_object, "g")) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/helpers.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/helpers.py new file mode 100644 index 00000000..7b8b0870 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/helpers.py @@ -0,0 +1,836 @@ +import os +import pkgutil +import socket +import sys +import typing as t +import warnings +from datetime import datetime +from datetime import timedelta +from functools import lru_cache +from functools import update_wrapper +from threading import RLock + +import werkzeug.utils +from werkzeug.exceptions import NotFound +from werkzeug.routing import BuildError +from werkzeug.urls import url_quote + +from .globals import _app_ctx_stack +from .globals import _request_ctx_stack +from .globals import current_app +from .globals import request +from .globals import session +from .signals import message_flashed + +if t.TYPE_CHECKING: + from .wrappers import Response + + +def get_env() -> str: + """Get the environment the app is running in, indicated by the + :envvar:`FLASK_ENV` environment variable. The default is + ``'production'``. + """ + return os.environ.get("FLASK_ENV") or "production" + + +def get_debug_flag() -> bool: + """Get whether debug mode should be enabled for the app, indicated + by the :envvar:`FLASK_DEBUG` environment variable. The default is + ``True`` if :func:`.get_env` returns ``'development'``, or ``False`` + otherwise. + """ + val = os.environ.get("FLASK_DEBUG") + + if not val: + return get_env() == "development" + + return val.lower() not in ("0", "false", "no") + + +def get_load_dotenv(default: bool = True) -> bool: + """Get whether the user has disabled loading dotenv files by setting + :envvar:`FLASK_SKIP_DOTENV`. The default is ``True``, load the + files. + + :param default: What to return if the env var isn't set. + """ + val = os.environ.get("FLASK_SKIP_DOTENV") + + if not val: + return default + + return val.lower() in ("0", "false", "no") + + +def stream_with_context( + generator_or_function: t.Union[ + t.Iterator[t.AnyStr], t.Callable[..., t.Iterator[t.AnyStr]] + ] +) -> t.Iterator[t.AnyStr]: + """Request contexts disappear when the response is started on the server. + This is done for efficiency reasons and to make it less likely to encounter + memory leaks with badly written WSGI middlewares. The downside is that if + you are using streamed responses, the generator cannot access request bound + information any more. + + This function however can help you keep the context around for longer:: + + from flask import stream_with_context, request, Response + + @app.route('/stream') + def streamed_response(): + @stream_with_context + def generate(): + yield 'Hello ' + yield request.args['name'] + yield '!' + return Response(generate()) + + Alternatively it can also be used around a specific generator:: + + from flask import stream_with_context, request, Response + + @app.route('/stream') + def streamed_response(): + def generate(): + yield 'Hello ' + yield request.args['name'] + yield '!' + return Response(stream_with_context(generate())) + + .. versionadded:: 0.9 + """ + try: + gen = iter(generator_or_function) # type: ignore + except TypeError: + + def decorator(*args: t.Any, **kwargs: t.Any) -> t.Any: + gen = generator_or_function(*args, **kwargs) # type: ignore + return stream_with_context(gen) + + return update_wrapper(decorator, generator_or_function) # type: ignore + + def generator() -> t.Generator: + ctx = _request_ctx_stack.top + if ctx is None: + raise RuntimeError( + "Attempted to stream with context but " + "there was no context in the first place to keep around." + ) + with ctx: + # Dummy sentinel. Has to be inside the context block or we're + # not actually keeping the context around. + yield None + + # The try/finally is here so that if someone passes a WSGI level + # iterator in we're still running the cleanup logic. Generators + # don't need that because they are closed on their destruction + # automatically. + try: + yield from gen + finally: + if hasattr(gen, "close"): + gen.close() # type: ignore + + # The trick is to start the generator. Then the code execution runs until + # the first dummy None is yielded at which point the context was already + # pushed. This item is discarded. Then when the iteration continues the + # real generator is executed. + wrapped_g = generator() + next(wrapped_g) + return wrapped_g + + +def make_response(*args: t.Any) -> "Response": + """Sometimes it is necessary to set additional headers in a view. Because + views do not have to return response objects but can return a value that + is converted into a response object by Flask itself, it becomes tricky to + add headers to it. This function can be called instead of using a return + and you will get a response object which you can use to attach headers. + + If view looked like this and you want to add a new header:: + + def index(): + return render_template('index.html', foo=42) + + You can now do something like this:: + + def index(): + response = make_response(render_template('index.html', foo=42)) + response.headers['X-Parachutes'] = 'parachutes are cool' + return response + + This function accepts the very same arguments you can return from a + view function. This for example creates a response with a 404 error + code:: + + response = make_response(render_template('not_found.html'), 404) + + The other use case of this function is to force the return value of a + view function into a response which is helpful with view + decorators:: + + response = make_response(view_function()) + response.headers['X-Parachutes'] = 'parachutes are cool' + + Internally this function does the following things: + + - if no arguments are passed, it creates a new response argument + - if one argument is passed, :meth:`flask.Flask.make_response` + is invoked with it. + - if more than one argument is passed, the arguments are passed + to the :meth:`flask.Flask.make_response` function as tuple. + + .. versionadded:: 0.6 + """ + if not args: + return current_app.response_class() + if len(args) == 1: + args = args[0] + return current_app.make_response(args) + + +def url_for(endpoint: str, **values: t.Any) -> str: + """Generates a URL to the given endpoint with the method provided. + + Variable arguments that are unknown to the target endpoint are appended + to the generated URL as query arguments. If the value of a query argument + is ``None``, the whole pair is skipped. In case blueprints are active + you can shortcut references to the same blueprint by prefixing the + local endpoint with a dot (``.``). + + This will reference the index function local to the current blueprint:: + + url_for('.index') + + See :ref:`url-building`. + + Configuration values ``APPLICATION_ROOT`` and ``SERVER_NAME`` are only used when + generating URLs outside of a request context. + + To integrate applications, :class:`Flask` has a hook to intercept URL build + errors through :attr:`Flask.url_build_error_handlers`. The `url_for` + function results in a :exc:`~werkzeug.routing.BuildError` when the current + app does not have a URL for the given endpoint and values. When it does, the + :data:`~flask.current_app` calls its :attr:`~Flask.url_build_error_handlers` if + it is not ``None``, which can return a string to use as the result of + `url_for` (instead of `url_for`'s default to raise the + :exc:`~werkzeug.routing.BuildError` exception) or re-raise the exception. + An example:: + + def external_url_handler(error, endpoint, values): + "Looks up an external URL when `url_for` cannot build a URL." + # This is an example of hooking the build_error_handler. + # Here, lookup_url is some utility function you've built + # which looks up the endpoint in some external URL registry. + url = lookup_url(endpoint, **values) + if url is None: + # External lookup did not have a URL. + # Re-raise the BuildError, in context of original traceback. + exc_type, exc_value, tb = sys.exc_info() + if exc_value is error: + raise exc_type(exc_value).with_traceback(tb) + else: + raise error + # url_for will use this result, instead of raising BuildError. + return url + + app.url_build_error_handlers.append(external_url_handler) + + Here, `error` is the instance of :exc:`~werkzeug.routing.BuildError`, and + `endpoint` and `values` are the arguments passed into `url_for`. Note + that this is for building URLs outside the current application, and not for + handling 404 NotFound errors. + + .. versionadded:: 0.10 + The `_scheme` parameter was added. + + .. versionadded:: 0.9 + The `_anchor` and `_method` parameters were added. + + .. versionadded:: 0.9 + Calls :meth:`Flask.handle_build_error` on + :exc:`~werkzeug.routing.BuildError`. + + :param endpoint: the endpoint of the URL (name of the function) + :param values: the variable arguments of the URL rule + :param _external: if set to ``True``, an absolute URL is generated. Server + address can be changed via ``SERVER_NAME`` configuration variable which + falls back to the `Host` header, then to the IP and port of the request. + :param _scheme: a string specifying the desired URL scheme. The `_external` + parameter must be set to ``True`` or a :exc:`ValueError` is raised. The default + behavior uses the same scheme as the current request, or + :data:`PREFERRED_URL_SCHEME` if no request context is available. + This also can be set to an empty string to build protocol-relative + URLs. + :param _anchor: if provided this is added as anchor to the URL. + :param _method: if provided this explicitly specifies an HTTP method. + """ + appctx = _app_ctx_stack.top + reqctx = _request_ctx_stack.top + + if appctx is None: + raise RuntimeError( + "Attempted to generate a URL without the application context being" + " pushed. This has to be executed when application context is" + " available." + ) + + # If request specific information is available we have some extra + # features that support "relative" URLs. + if reqctx is not None: + url_adapter = reqctx.url_adapter + blueprint_name = request.blueprint + + if endpoint[:1] == ".": + if blueprint_name is not None: + endpoint = f"{blueprint_name}{endpoint}" + else: + endpoint = endpoint[1:] + + external = values.pop("_external", False) + + # Otherwise go with the url adapter from the appctx and make + # the URLs external by default. + else: + url_adapter = appctx.url_adapter + + if url_adapter is None: + raise RuntimeError( + "Application was not able to create a URL adapter for request" + " independent URL generation. You might be able to fix this by" + " setting the SERVER_NAME config variable." + ) + + external = values.pop("_external", True) + + anchor = values.pop("_anchor", None) + method = values.pop("_method", None) + scheme = values.pop("_scheme", None) + appctx.app.inject_url_defaults(endpoint, values) + + # This is not the best way to deal with this but currently the + # underlying Werkzeug router does not support overriding the scheme on + # a per build call basis. + old_scheme = None + if scheme is not None: + if not external: + raise ValueError("When specifying _scheme, _external must be True") + old_scheme = url_adapter.url_scheme + url_adapter.url_scheme = scheme + + try: + try: + rv = url_adapter.build( + endpoint, values, method=method, force_external=external + ) + finally: + if old_scheme is not None: + url_adapter.url_scheme = old_scheme + except BuildError as error: + # We need to inject the values again so that the app callback can + # deal with that sort of stuff. + values["_external"] = external + values["_anchor"] = anchor + values["_method"] = method + values["_scheme"] = scheme + return appctx.app.handle_url_build_error(error, endpoint, values) + + if anchor is not None: + rv += f"#{url_quote(anchor)}" + return rv + + +def get_template_attribute(template_name: str, attribute: str) -> t.Any: + """Loads a macro (or variable) a template exports. This can be used to + invoke a macro from within Python code. If you for example have a + template named :file:`_cider.html` with the following contents: + + .. sourcecode:: html+jinja + + {% macro hello(name) %}Hello {{ name }}!{% endmacro %} + + You can access this from Python code like this:: + + hello = get_template_attribute('_cider.html', 'hello') + return hello('World') + + .. versionadded:: 0.2 + + :param template_name: the name of the template + :param attribute: the name of the variable of macro to access + """ + return getattr(current_app.jinja_env.get_template(template_name).module, attribute) + + +def flash(message: str, category: str = "message") -> None: + """Flashes a message to the next request. In order to remove the + flashed message from the session and to display it to the user, + the template has to call :func:`get_flashed_messages`. + + .. versionchanged:: 0.3 + `category` parameter added. + + :param message: the message to be flashed. + :param category: the category for the message. The following values + are recommended: ``'message'`` for any kind of message, + ``'error'`` for errors, ``'info'`` for information + messages and ``'warning'`` for warnings. However any + kind of string can be used as category. + """ + # Original implementation: + # + # session.setdefault('_flashes', []).append((category, message)) + # + # This assumed that changes made to mutable structures in the session are + # always in sync with the session object, which is not true for session + # implementations that use external storage for keeping their keys/values. + flashes = session.get("_flashes", []) + flashes.append((category, message)) + session["_flashes"] = flashes + message_flashed.send( + current_app._get_current_object(), # type: ignore + message=message, + category=category, + ) + + +def get_flashed_messages( + with_categories: bool = False, category_filter: t.Iterable[str] = () +) -> t.Union[t.List[str], t.List[t.Tuple[str, str]]]: + """Pulls all flashed messages from the session and returns them. + Further calls in the same request to the function will return + the same messages. By default just the messages are returned, + but when `with_categories` is set to ``True``, the return value will + be a list of tuples in the form ``(category, message)`` instead. + + Filter the flashed messages to one or more categories by providing those + categories in `category_filter`. This allows rendering categories in + separate html blocks. The `with_categories` and `category_filter` + arguments are distinct: + + * `with_categories` controls whether categories are returned with message + text (``True`` gives a tuple, where ``False`` gives just the message text). + * `category_filter` filters the messages down to only those matching the + provided categories. + + See :doc:`/patterns/flashing` for examples. + + .. versionchanged:: 0.3 + `with_categories` parameter added. + + .. versionchanged:: 0.9 + `category_filter` parameter added. + + :param with_categories: set to ``True`` to also receive categories. + :param category_filter: filter of categories to limit return values. Only + categories in the list will be returned. + """ + flashes = _request_ctx_stack.top.flashes + if flashes is None: + _request_ctx_stack.top.flashes = flashes = ( + session.pop("_flashes") if "_flashes" in session else [] + ) + if category_filter: + flashes = list(filter(lambda f: f[0] in category_filter, flashes)) + if not with_categories: + return [x[1] for x in flashes] + return flashes + + +def _prepare_send_file_kwargs( + download_name: t.Optional[str] = None, + attachment_filename: t.Optional[str] = None, + etag: t.Optional[t.Union[bool, str]] = None, + add_etags: t.Optional[t.Union[bool]] = None, + max_age: t.Optional[ + t.Union[int, t.Callable[[t.Optional[str]], t.Optional[int]]] + ] = None, + cache_timeout: t.Optional[int] = None, + **kwargs: t.Any, +) -> t.Dict[str, t.Any]: + if attachment_filename is not None: + warnings.warn( + "The 'attachment_filename' parameter has been renamed to" + " 'download_name'. The old name will be removed in Flask" + " 2.1.", + DeprecationWarning, + stacklevel=3, + ) + download_name = attachment_filename + + if cache_timeout is not None: + warnings.warn( + "The 'cache_timeout' parameter has been renamed to" + " 'max_age'. The old name will be removed in Flask 2.1.", + DeprecationWarning, + stacklevel=3, + ) + max_age = cache_timeout + + if add_etags is not None: + warnings.warn( + "The 'add_etags' parameter has been renamed to 'etag'. The" + " old name will be removed in Flask 2.1.", + DeprecationWarning, + stacklevel=3, + ) + etag = add_etags + + if max_age is None: + max_age = current_app.get_send_file_max_age + + kwargs.update( + environ=request.environ, + download_name=download_name, + etag=etag, + max_age=max_age, + use_x_sendfile=current_app.use_x_sendfile, + response_class=current_app.response_class, + _root_path=current_app.root_path, # type: ignore + ) + return kwargs + + +def send_file( + path_or_file: t.Union[os.PathLike, str, t.BinaryIO], + mimetype: t.Optional[str] = None, + as_attachment: bool = False, + download_name: t.Optional[str] = None, + attachment_filename: t.Optional[str] = None, + conditional: bool = True, + etag: t.Union[bool, str] = True, + add_etags: t.Optional[bool] = None, + last_modified: t.Optional[t.Union[datetime, int, float]] = None, + max_age: t.Optional[ + t.Union[int, t.Callable[[t.Optional[str]], t.Optional[int]]] + ] = None, + cache_timeout: t.Optional[int] = None, +): + """Send the contents of a file to the client. + + The first argument can be a file path or a file-like object. Paths + are preferred in most cases because Werkzeug can manage the file and + get extra information from the path. Passing a file-like object + requires that the file is opened in binary mode, and is mostly + useful when building a file in memory with :class:`io.BytesIO`. + + Never pass file paths provided by a user. The path is assumed to be + trusted, so a user could craft a path to access a file you didn't + intend. Use :func:`send_from_directory` to safely serve + user-requested paths from within a directory. + + If the WSGI server sets a ``file_wrapper`` in ``environ``, it is + used, otherwise Werkzeug's built-in wrapper is used. Alternatively, + if the HTTP server supports ``X-Sendfile``, configuring Flask with + ``USE_X_SENDFILE = True`` will tell the server to send the given + path, which is much more efficient than reading it in Python. + + :param path_or_file: The path to the file to send, relative to the + current working directory if a relative path is given. + Alternatively, a file-like object opened in binary mode. Make + sure the file pointer is seeked to the start of the data. + :param mimetype: The MIME type to send for the file. If not + provided, it will try to detect it from the file name. + :param as_attachment: Indicate to a browser that it should offer to + save the file instead of displaying it. + :param download_name: The default name browsers will use when saving + the file. Defaults to the passed file name. + :param conditional: Enable conditional and range responses based on + request headers. Requires passing a file path and ``environ``. + :param etag: Calculate an ETag for the file, which requires passing + a file path. Can also be a string to use instead. + :param last_modified: The last modified time to send for the file, + in seconds. If not provided, it will try to detect it from the + file path. + :param max_age: How long the client should cache the file, in + seconds. If set, ``Cache-Control`` will be ``public``, otherwise + it will be ``no-cache`` to prefer conditional caching. + + .. versionchanged:: 2.0 + ``download_name`` replaces the ``attachment_filename`` + parameter. If ``as_attachment=False``, it is passed with + ``Content-Disposition: inline`` instead. + + .. versionchanged:: 2.0 + ``max_age`` replaces the ``cache_timeout`` parameter. + ``conditional`` is enabled and ``max_age`` is not set by + default. + + .. versionchanged:: 2.0 + ``etag`` replaces the ``add_etags`` parameter. It can be a + string to use instead of generating one. + + .. versionchanged:: 2.0 + Passing a file-like object that inherits from + :class:`~io.TextIOBase` will raise a :exc:`ValueError` rather + than sending an empty file. + + .. versionadded:: 2.0 + Moved the implementation to Werkzeug. This is now a wrapper to + pass some Flask-specific arguments. + + .. versionchanged:: 1.1 + ``filename`` may be a :class:`~os.PathLike` object. + + .. versionchanged:: 1.1 + Passing a :class:`~io.BytesIO` object supports range requests. + + .. versionchanged:: 1.0.3 + Filenames are encoded with ASCII instead of Latin-1 for broader + compatibility with WSGI servers. + + .. versionchanged:: 1.0 + UTF-8 filenames as specified in :rfc:`2231` are supported. + + .. versionchanged:: 0.12 + The filename is no longer automatically inferred from file + objects. If you want to use automatic MIME and etag support, + pass a filename via ``filename_or_fp`` or + ``attachment_filename``. + + .. versionchanged:: 0.12 + ``attachment_filename`` is preferred over ``filename`` for MIME + detection. + + .. versionchanged:: 0.9 + ``cache_timeout`` defaults to + :meth:`Flask.get_send_file_max_age`. + + .. versionchanged:: 0.7 + MIME guessing and etag support for file-like objects was + deprecated because it was unreliable. Pass a filename if you are + able to, otherwise attach an etag yourself. + + .. versionchanged:: 0.5 + The ``add_etags``, ``cache_timeout`` and ``conditional`` + parameters were added. The default behavior is to add etags. + + .. versionadded:: 0.2 + """ + return werkzeug.utils.send_file( + **_prepare_send_file_kwargs( + path_or_file=path_or_file, + environ=request.environ, + mimetype=mimetype, + as_attachment=as_attachment, + download_name=download_name, + attachment_filename=attachment_filename, + conditional=conditional, + etag=etag, + add_etags=add_etags, + last_modified=last_modified, + max_age=max_age, + cache_timeout=cache_timeout, + ) + ) + + +def safe_join(directory: str, *pathnames: str) -> str: + """Safely join zero or more untrusted path components to a base + directory to avoid escaping the base directory. + + :param directory: The trusted base directory. + :param pathnames: The untrusted path components relative to the + base directory. + :return: A safe path, otherwise ``None``. + """ + warnings.warn( + "'flask.helpers.safe_join' is deprecated and will be removed in" + " Flask 2.1. Use 'werkzeug.utils.safe_join' instead.", + DeprecationWarning, + stacklevel=2, + ) + path = werkzeug.utils.safe_join(directory, *pathnames) + + if path is None: + raise NotFound() + + return path + + +def send_from_directory( + directory: t.Union[os.PathLike, str], + path: t.Union[os.PathLike, str], + filename: t.Optional[str] = None, + **kwargs: t.Any, +) -> "Response": + """Send a file from within a directory using :func:`send_file`. + + .. code-block:: python + + @app.route("/uploads/") + def download_file(name): + return send_from_directory( + app.config['UPLOAD_FOLDER'], name, as_attachment=True + ) + + This is a secure way to serve files from a folder, such as static + files or uploads. Uses :func:`~werkzeug.security.safe_join` to + ensure the path coming from the client is not maliciously crafted to + point outside the specified directory. + + If the final path does not point to an existing regular file, + raises a 404 :exc:`~werkzeug.exceptions.NotFound` error. + + :param directory: The directory that ``path`` must be located under. + :param path: The path to the file to send, relative to + ``directory``. + :param kwargs: Arguments to pass to :func:`send_file`. + + .. versionchanged:: 2.0 + ``path`` replaces the ``filename`` parameter. + + .. versionadded:: 2.0 + Moved the implementation to Werkzeug. This is now a wrapper to + pass some Flask-specific arguments. + + .. versionadded:: 0.5 + """ + if filename is not None: + warnings.warn( + "The 'filename' parameter has been renamed to 'path'. The" + " old name will be removed in Flask 2.1.", + DeprecationWarning, + stacklevel=2, + ) + path = filename + + return werkzeug.utils.send_from_directory( # type: ignore + directory, path, **_prepare_send_file_kwargs(**kwargs) + ) + + +def get_root_path(import_name: str) -> str: + """Find the root path of a package, or the path that contains a + module. If it cannot be found, returns the current working + directory. + + Not to be confused with the value returned by :func:`find_package`. + + :meta private: + """ + # Module already imported and has a file attribute. Use that first. + mod = sys.modules.get(import_name) + + if mod is not None and hasattr(mod, "__file__"): + return os.path.dirname(os.path.abspath(mod.__file__)) + + # Next attempt: check the loader. + loader = pkgutil.get_loader(import_name) + + # Loader does not exist or we're referring to an unloaded main + # module or a main module without path (interactive sessions), go + # with the current working directory. + if loader is None or import_name == "__main__": + return os.getcwd() + + if hasattr(loader, "get_filename"): + filepath = loader.get_filename(import_name) # type: ignore + else: + # Fall back to imports. + __import__(import_name) + mod = sys.modules[import_name] + filepath = getattr(mod, "__file__", None) + + # If we don't have a file path it might be because it is a + # namespace package. In this case pick the root path from the + # first module that is contained in the package. + if filepath is None: + raise RuntimeError( + "No root path can be found for the provided module" + f" {import_name!r}. This can happen because the module" + " came from an import hook that does not provide file" + " name information or because it's a namespace package." + " In this case the root path needs to be explicitly" + " provided." + ) + + # filepath is import_name.py for a module, or __init__.py for a package. + return os.path.dirname(os.path.abspath(filepath)) + + +class locked_cached_property(werkzeug.utils.cached_property): + """A :func:`property` that is only evaluated once. Like + :class:`werkzeug.utils.cached_property` except access uses a lock + for thread safety. + + .. versionchanged:: 2.0 + Inherits from Werkzeug's ``cached_property`` (and ``property``). + """ + + def __init__( + self, + fget: t.Callable[[t.Any], t.Any], + name: t.Optional[str] = None, + doc: t.Optional[str] = None, + ) -> None: + super().__init__(fget, name=name, doc=doc) + self.lock = RLock() + + def __get__(self, obj: object, type: type = None) -> t.Any: # type: ignore + if obj is None: + return self + + with self.lock: + return super().__get__(obj, type=type) + + def __set__(self, obj: object, value: t.Any) -> None: + with self.lock: + super().__set__(obj, value) + + def __delete__(self, obj: object) -> None: + with self.lock: + super().__delete__(obj) + + +def total_seconds(td: timedelta) -> int: + """Returns the total seconds from a timedelta object. + + :param timedelta td: the timedelta to be converted in seconds + + :returns: number of seconds + :rtype: int + + .. deprecated:: 2.0 + Will be removed in Flask 2.1. Use + :meth:`timedelta.total_seconds` instead. + """ + warnings.warn( + "'total_seconds' is deprecated and will be removed in Flask" + " 2.1. Use 'timedelta.total_seconds' instead.", + DeprecationWarning, + stacklevel=2, + ) + return td.days * 60 * 60 * 24 + td.seconds + + +def is_ip(value: str) -> bool: + """Determine if the given string is an IP address. + + :param value: value to check + :type value: str + + :return: True if string is an IP address + :rtype: bool + """ + for family in (socket.AF_INET, socket.AF_INET6): + try: + socket.inet_pton(family, value) + except OSError: + pass + else: + return True + + return False + + +@lru_cache(maxsize=None) +def _split_blueprint_path(name: str) -> t.List[str]: + out: t.List[str] = [name] + + if "." in name: + out.extend(_split_blueprint_path(name.rpartition(".")[0])) + + return out diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__init__.py new file mode 100644 index 00000000..10d5123a --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/flask/json/__init__.py @@ -0,0 +1,357 @@ +import decimal +import io +import json as _json +import typing as t +import uuid +import warnings +from datetime import date + +from jinja2.utils import htmlsafe_json_dumps as _jinja_htmlsafe_dumps +from werkzeug.http import http_date + +from ..globals import current_app +from ..globals import request + +if t.TYPE_CHECKING: + from ..app import Flask + from ..wrappers import Response + +try: + import dataclasses +except ImportError: + # Python < 3.7 + dataclasses = None # type: ignore + + +class JSONEncoder(_json.JSONEncoder): + """The default JSON encoder. Handles extra types compared to the + built-in :class:`json.JSONEncoder`. + + - :class:`datetime.datetime` and :class:`datetime.date` are + serialized to :rfc:`822` strings. This is the same as the HTTP + date format. + - :class:`uuid.UUID` is serialized to a string. + - :class:`dataclasses.dataclass` is passed to + :func:`dataclasses.asdict`. + - :class:`~markupsafe.Markup` (or any object with a ``__html__`` + method) will call the ``__html__`` method to get a string. + + Assign a subclass of this to :attr:`flask.Flask.json_encoder` or + :attr:`flask.Blueprint.json_encoder` to override the default. + """ + + def default(self, o: t.Any) -> t.Any: + """Convert ``o`` to a JSON serializable type. See + :meth:`json.JSONEncoder.default`. Python does not support + overriding how basic types like ``str`` or ``list`` are + serialized, they are handled before this method. + """ + if isinstance(o, date): + return http_date(o) + if isinstance(o, (decimal.Decimal, uuid.UUID)): + return str(o) + if dataclasses and dataclasses.is_dataclass(o): + return dataclasses.asdict(o) + if hasattr(o, "__html__"): + return str(o.__html__()) + return super().default(o) + + +class JSONDecoder(_json.JSONDecoder): + """The default JSON decoder. + + This does not change any behavior from the built-in + :class:`json.JSONDecoder`. + + Assign a subclass of this to :attr:`flask.Flask.json_decoder` or + :attr:`flask.Blueprint.json_decoder` to override the default. + """ + + +def _dump_arg_defaults( + kwargs: t.Dict[str, t.Any], app: t.Optional["Flask"] = None +) -> None: + """Inject default arguments for dump functions.""" + if app is None: + app = current_app + + if app: + cls = app.json_encoder + bp = app.blueprints.get(request.blueprint) if request else None # type: ignore + if bp is not None and bp.json_encoder is not None: + cls = bp.json_encoder + + kwargs.setdefault("cls", cls) + kwargs.setdefault("ensure_ascii", app.config["JSON_AS_ASCII"]) + kwargs.setdefault("sort_keys", app.config["JSON_SORT_KEYS"]) + else: + kwargs.setdefault("sort_keys", True) + kwargs.setdefault("cls", JSONEncoder) + + +def _load_arg_defaults( + kwargs: t.Dict[str, t.Any], app: t.Optional["Flask"] = None +) -> None: + """Inject default arguments for load functions.""" + if app is None: + app = current_app + + if app: + cls = app.json_decoder + bp = app.blueprints.get(request.blueprint) if request else None # type: ignore + if bp is not None and bp.json_decoder is not None: + cls = bp.json_decoder + + kwargs.setdefault("cls", cls) + else: + kwargs.setdefault("cls", JSONDecoder) + + +def dumps(obj: t.Any, app: t.Optional["Flask"] = None, **kwargs: t.Any) -> str: + """Serialize an object to a string of JSON. + + Takes the same arguments as the built-in :func:`json.dumps`, with + some defaults from application configuration. + + :param obj: Object to serialize to JSON. + :param app: Use this app's config instead of the active app context + or defaults. + :param kwargs: Extra arguments passed to :func:`json.dumps`. + + .. versionchanged:: 2.0.2 + :class:`decimal.Decimal` is supported by converting to a string. + + .. versionchanged:: 2.0 + ``encoding`` is deprecated and will be removed in Flask 2.1. + + .. versionchanged:: 1.0.3 + ``app`` can be passed directly, rather than requiring an app + context for configuration. + """ + _dump_arg_defaults(kwargs, app=app) + encoding = kwargs.pop("encoding", None) + rv = _json.dumps(obj, **kwargs) + + if encoding is not None: + warnings.warn( + "'encoding' is deprecated and will be removed in Flask 2.1.", + DeprecationWarning, + stacklevel=2, + ) + + if isinstance(rv, str): + return rv.encode(encoding) # type: ignore + + return rv + + +def dump( + obj: t.Any, fp: t.IO[str], app: t.Optional["Flask"] = None, **kwargs: t.Any +) -> None: + """Serialize an object to JSON written to a file object. + + Takes the same arguments as the built-in :func:`json.dump`, with + some defaults from application configuration. + + :param obj: Object to serialize to JSON. + :param fp: File object to write JSON to. + :param app: Use this app's config instead of the active app context + or defaults. + :param kwargs: Extra arguments passed to :func:`json.dump`. + + .. versionchanged:: 2.0 + Writing to a binary file, and the ``encoding`` argument, is + deprecated and will be removed in Flask 2.1. + """ + _dump_arg_defaults(kwargs, app=app) + encoding = kwargs.pop("encoding", None) + show_warning = encoding is not None + + try: + fp.write("") + except TypeError: + show_warning = True + fp = io.TextIOWrapper(fp, encoding or "utf-8") # type: ignore + + if show_warning: + warnings.warn( + "Writing to a binary file, and the 'encoding' argument, is" + " deprecated and will be removed in Flask 2.1.", + DeprecationWarning, + stacklevel=2, + ) + + _json.dump(obj, fp, **kwargs) + + +def loads(s: str, app: t.Optional["Flask"] = None, **kwargs: t.Any) -> t.Any: + """Deserialize an object from a string of JSON. + + Takes the same arguments as the built-in :func:`json.loads`, with + some defaults from application configuration. + + :param s: JSON string to deserialize. + :param app: Use this app's config instead of the active app context + or defaults. + :param kwargs: Extra arguments passed to :func:`json.loads`. + + .. versionchanged:: 2.0 + ``encoding`` is deprecated and will be removed in Flask 2.1. The + data must be a string or UTF-8 bytes. + + .. versionchanged:: 1.0.3 + ``app`` can be passed directly, rather than requiring an app + context for configuration. + """ + _load_arg_defaults(kwargs, app=app) + encoding = kwargs.pop("encoding", None) + + if encoding is not None: + warnings.warn( + "'encoding' is deprecated and will be removed in Flask 2.1." + " The data must be a string or UTF-8 bytes.", + DeprecationWarning, + stacklevel=2, + ) + + if isinstance(s, bytes): + s = s.decode(encoding) + + return _json.loads(s, **kwargs) + + +def load(fp: t.IO[str], app: t.Optional["Flask"] = None, **kwargs: t.Any) -> t.Any: + """Deserialize an object from JSON read from a file object. + + Takes the same arguments as the built-in :func:`json.load`, with + some defaults from application configuration. + + :param fp: File object to read JSON from. + :param app: Use this app's config instead of the active app context + or defaults. + :param kwargs: Extra arguments passed to :func:`json.load`. + + .. versionchanged:: 2.0 + ``encoding`` is deprecated and will be removed in Flask 2.1. The + file must be text mode, or binary mode with UTF-8 bytes. + """ + _load_arg_defaults(kwargs, app=app) + encoding = kwargs.pop("encoding", None) + + if encoding is not None: + warnings.warn( + "'encoding' is deprecated and will be removed in Flask 2.1." + " The file must be text mode, or binary mode with UTF-8" + " bytes.", + DeprecationWarning, + stacklevel=2, + ) + + if isinstance(fp.read(0), bytes): + fp = io.TextIOWrapper(fp, encoding) # type: ignore + + return _json.load(fp, **kwargs) + + +def htmlsafe_dumps(obj: t.Any, **kwargs: t.Any) -> str: + """Serialize an object to a string of JSON with :func:`dumps`, then + replace HTML-unsafe characters with Unicode escapes and mark the + result safe with :class:`~markupsafe.Markup`. + + This is available in templates as the ``|tojson`` filter. + + The returned string is safe to render in HTML documents and + ``') + # => <script> do_nasty_stuff() </script> + # sanitize_html('Click here for $100') + # => Click here for $100 + 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"] = "" % 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/Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py new file mode 100644 index 00000000..0d12584b --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/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/Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/html5parser.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/html5parser.py new file mode 100644 index 00000000..d06784f3 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/pip/_vendor/html5lib/html5parser.py @@ -0,0 +1,2795 @@ +from __future__ import absolute_import, division, unicode_literals +from pip._vendor.six import with_metaclass, viewkeys + +import types + +from . import _inputstream +from . import _tokenizer + +from . import treebuilders +from .treebuilders.base import Marker + +from . import _utils +from .constants import ( + spaceCharacters, asciiUpper2Lower, + specialElements, headingElements, cdataElements, rcdataElements, + tokenTypes, tagTokenTypes, + namespaces, + htmlIntegrationPointElements, mathmlTextIntegrationPointElements, + adjustForeignAttributes as adjustForeignAttributesMap, + adjustMathMLAttributes, adjustSVGAttributes, + E, + _ReparseException +) + + +def parse(doc, treebuilder="etree", namespaceHTMLElements=True, **kwargs): + """Parse an HTML document as a string or file-like object into a tree + + :arg doc: the document to parse as a string or file-like object + + :arg treebuilder: the treebuilder to use when parsing + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + :returns: parsed tree + + Example: + + >>> from html5lib.html5parser import parse + >>> parse('

This is a doc

') + + + """ + 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('this is a fragment') + + + """ + tb = treebuilders.getTreeBuilder(treebuilder) + p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements) + return p.parseFragment(doc, container=container, **kwargs) + + +def method_decorator_metaclass(function): + class Decorated(type): + def __new__(meta, classname, bases, classDict): + for attributeName, attribute in classDict.items(): + if isinstance(attribute, types.FunctionType): + attribute = function(attribute) + + classDict[attributeName] = attribute + return type.__new__(meta, classname, bases, classDict) + return Decorated + + +class HTMLParser(object): + """HTML parser + + Generates a tree structure from a stream of (possibly malformed) HTML. + + """ + + def __init__(self, tree=None, strict=False, namespaceHTMLElements=True, debug=False): + """ + :arg tree: a treebuilder class controlling the type of tree that will be + returned. Built in treebuilders can be accessed through + html5lib.treebuilders.getTreeBuilder(treeType) + + :arg strict: raise an exception when a parse error is encountered + + :arg namespaceHTMLElements: whether or not to namespace HTML elements + + :arg debug: whether or not to enable debug mode which logs things + + Example: + + >>> from html5lib.html5parser import HTMLParser + >>> parser = HTMLParser() # generates parser with etree builder + >>> parser = HTMLParser('lxml', strict=True) # generates parser with lxml builder which is strict + + """ + + # Raise an exception on the first error encountered + self.strict = strict + + if tree is None: + tree = treebuilders.getTreeBuilder("etree") + self.tree = tree(namespaceHTMLElements) + self.errors = [] + + self.phases = {name: cls(self, self.tree) for name, cls in + getPhases(debug).items()} + + def _parse(self, stream, innerHTML=False, container="div", scripting=False, **kwargs): + + self.innerHTMLMode = innerHTML + self.container = container + self.scripting = scripting + self.tokenizer = _tokenizer.HTMLTokenizer(stream, parser=self, **kwargs) + self.reset() + + try: + self.mainLoop() + except _ReparseException: + self.reset() + self.mainLoop() + + def reset(self): + self.tree.reset() + self.firstStartTag = False + self.errors = [] + self.log = [] # only used with debug mode + # "quirks" / "limited quirks" / "no quirks" + self.compatMode = "no quirks" + + if self.innerHTMLMode: + self.innerHTML = self.container.lower() + + if self.innerHTML in cdataElements: + self.tokenizer.state = self.tokenizer.rcdataState + elif self.innerHTML in rcdataElements: + self.tokenizer.state = self.tokenizer.rawtextState + elif self.innerHTML == 'plaintext': + self.tokenizer.state = self.tokenizer.plaintextState + else: + # state already is data state + # self.tokenizer.state = self.tokenizer.dataState + pass + self.phase = self.phases["beforeHtml"] + self.phase.insertHtmlElement() + self.resetInsertionMode() + else: + self.innerHTML = False # pylint:disable=redefined-variable-type + self.phase = self.phases["initial"] + + self.lastPhase = None + + self.beforeRCDataPhase = None + + self.framesetOK = True + + @property + def documentEncoding(self): + """Name of the character encoding that was used to decode the input stream, or + :obj:`None` if that is not determined yet + + """ + if not hasattr(self, 'tokenizer'): + return None + return self.tokenizer.stream.charEncoding[0].name + + def isHTMLIntegrationPoint(self, element): + if (element.name == "annotation-xml" and + element.namespace == namespaces["mathml"]): + return ("encoding" in element.attributes and + element.attributes["encoding"].translate( + asciiUpper2Lower) in + ("text/html", "application/xhtml+xml")) + else: + return (element.namespace, element.name) in htmlIntegrationPointElements + + def isMathMLTextIntegrationPoint(self, element): + return (element.namespace, element.name) in mathmlTextIntegrationPointElements + + def mainLoop(self): + CharactersToken = tokenTypes["Characters"] + SpaceCharactersToken = tokenTypes["SpaceCharacters"] + StartTagToken = tokenTypes["StartTag"] + EndTagToken = tokenTypes["EndTag"] + CommentToken = tokenTypes["Comment"] + DoctypeToken = tokenTypes["Doctype"] + ParseErrorToken = tokenTypes["ParseError"] + + for token in self.tokenizer: + prev_token = None + new_token = token + while new_token is not None: + prev_token = new_token + currentNode = self.tree.openElements[-1] if self.tree.openElements else None + currentNodeNamespace = currentNode.namespace if currentNode else None + currentNodeName = currentNode.name if currentNode else None + + type = new_token["type"] + + if type == ParseErrorToken: + self.parseError(new_token["data"], new_token.get("datavars", {})) + new_token = None + else: + if (len(self.tree.openElements) == 0 or + currentNodeNamespace == self.tree.defaultNamespace or + (self.isMathMLTextIntegrationPoint(currentNode) and + ((type == StartTagToken and + token["name"] not in frozenset(["mglyph", "malignmark"])) or + type in (CharactersToken, SpaceCharactersToken))) or + (currentNodeNamespace == namespaces["mathml"] and + currentNodeName == "annotation-xml" and + type == StartTagToken and + token["name"] == "svg") or + (self.isHTMLIntegrationPoint(currentNode) and + type in (StartTagToken, CharactersToken, SpaceCharactersToken))): + phase = self.phase + else: + phase = self.phases["inForeignContent"] + + if type == CharactersToken: + new_token = phase.processCharacters(new_token) + elif type == SpaceCharactersToken: + new_token = phase.processSpaceCharacters(new_token) + elif type == StartTagToken: + new_token = phase.processStartTag(new_token) + elif type == EndTagToken: + new_token = phase.processEndTag(new_token) + elif type == CommentToken: + new_token = phase.processComment(new_token) + elif type == DoctypeToken: + new_token = phase.processDoctype(new_token) + + if (type == StartTagToken and prev_token["selfClosing"] and + not prev_token["selfClosingAcknowledged"]): + self.parseError("non-void-element-with-trailing-solidus", + {"name": prev_token["name"]}) + + # When the loop finishes it's EOF + reprocess = True + phases = [] + while reprocess: + phases.append(self.phase) + reprocess = self.phase.processEOF() + if reprocess: + assert self.phase not in phases + + def parse(self, stream, *args, **kwargs): + """Parse a HTML document into a well-formed tree + + :arg stream: a file-like object or string containing the HTML to be parsed + + The optional encoding parameter must be a string that indicates + the encoding. If specified, that encoding will be used, + regardless of any BOM or later declaration (such as in a meta + element). + + :arg scripting: treat noscript elements as if JavaScript was turned on + + :returns: parsed tree + + Example: + + >>> from html5lib.html5parser import HTMLParser + >>> parser = HTMLParser() + >>> parser.parse('

This is a doc

') + + + """ + 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('this is a fragment') + + + """ + self._parse(stream, True, *args, **kwargs) + return self.tree.getFragment() + + def parseError(self, errorcode="XXX-undefined-error", datavars=None): + # XXX The idea is to make errorcode mandatory. + if datavars is None: + datavars = {} + self.errors.append((self.tokenizer.stream.position(), errorcode, datavars)) + if self.strict: + raise ParseError(E[errorcode] % datavars) + + def adjustMathMLAttributes(self, token): + adjust_attributes(token, adjustMathMLAttributes) + + def adjustSVGAttributes(self, token): + adjust_attributes(token, adjustSVGAttributes) + + def adjustForeignAttributes(self, token): + adjust_attributes(token, adjustForeignAttributesMap) + + def reparseTokenNormal(self, token): + # pylint:disable=unused-argument + self.parser.phase() + + def resetInsertionMode(self): + # The name of this method is mostly historical. (It's also used in the + # specification.) + last = False + newModes = { + "select": "inSelect", + "td": "inCell", + "th": "inCell", + "tr": "inRow", + "tbody": "inTableBody", + "thead": "inTableBody", + "tfoot": "inTableBody", + "caption": "inCaption", + "colgroup": "inColumnGroup", + "table": "inTable", + "head": "inBody", + "body": "inBody", + "frameset": "inFrameset", + "html": "beforeHead" + } + for node in self.tree.openElements[::-1]: + nodeName = node.name + new_phase = None + if node == self.tree.openElements[0]: + assert self.innerHTML + last = True + nodeName = self.innerHTML + # Check for conditions that should only happen in the innerHTML + # case + if nodeName in ("select", "colgroup", "head", "html"): + assert self.innerHTML + + if not last and node.namespace != self.tree.defaultNamespace: + continue + + if nodeName in newModes: + new_phase = self.phases[newModes[nodeName]] + break + elif last: + new_phase = self.phases["inBody"] + break + + self.phase = new_phase + + def parseRCDataRawtext(self, token, contentType): + # Generic RCDATA/RAWTEXT Parsing algorithm + assert contentType in ("RAWTEXT", "RCDATA") + + self.tree.insertElement(token) + + if contentType == "RAWTEXT": + self.tokenizer.state = self.tokenizer.rawtextState + else: + self.tokenizer.state = self.tokenizer.rcdataState + + self.originalPhase = self.phase + + self.phase = self.phases["text"] + + +@_utils.memoize +def getPhases(debug): + def log(function): + """Logger that records which phase processes each token""" + type_names = {value: key for key, value in tokenTypes.items()} + + def wrapped(self, *args, **kwargs): + if function.__name__.startswith("process") and len(args) > 0: + token = args[0] + info = {"type": type_names[token['type']]} + if token['type'] in tagTokenTypes: + info["name"] = token['name'] + + self.parser.log.append((self.parser.tokenizer.state.__name__, + self.parser.phase.__class__.__name__, + self.__class__.__name__, + function.__name__, + info)) + return function(self, *args, **kwargs) + else: + return function(self, *args, **kwargs) + return wrapped + + def getMetaclass(use_metaclass, metaclass_func): + if use_metaclass: + return method_decorator_metaclass(metaclass_func) + else: + return type + + # pylint:disable=unused-argument + class Phase(with_metaclass(getMetaclass(debug, log))): + """Base class for helper object that implements each phase of processing + """ + __slots__ = ("parser", "tree", "__startTagCache", "__endTagCache") + + def __init__(self, parser, tree): + self.parser = parser + self.tree = tree + self.__startTagCache = {} + self.__endTagCache = {} + + def processEOF(self): + raise NotImplementedError + + def processComment(self, token): + # For most phases the following is correct. Where it's not it will be + # overridden. + self.tree.insertComment(token, self.tree.openElements[-1]) + + def processDoctype(self, token): + self.parser.parseError("unexpected-doctype") + + def processCharacters(self, token): + self.tree.insertText(token["data"]) + + def processSpaceCharacters(self, token): + self.tree.insertText(token["data"]) + + def processStartTag(self, token): + # Note the caching is done here rather than BoundMethodDispatcher as doing it there + # requires a circular reference to the Phase, and this ends up with a significant + # (CPython 2.7, 3.8) GC cost when parsing many short inputs + name = token["name"] + # In Py2, using `in` is quicker in general than try/except KeyError + # In Py3, `in` is quicker when there are few cache hits (typically short inputs) + if name in self.__startTagCache: + func = self.__startTagCache[name] + else: + func = self.__startTagCache[name] = self.startTagHandler[name] + # bound the cache size in case we get loads of unknown tags + while len(self.__startTagCache) > len(self.startTagHandler) * 1.1: + # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7 + self.__startTagCache.pop(next(iter(self.__startTagCache))) + return func(token) + + def startTagHtml(self, token): + if not self.parser.firstStartTag and token["name"] == "html": + self.parser.parseError("non-html-root") + # XXX Need a check here to see if the first start tag token emitted is + # this token... If it's not, invoke self.parser.parseError(). + for attr, value in token["data"].items(): + if attr not in self.tree.openElements[0].attributes: + self.tree.openElements[0].attributes[attr] = value + self.parser.firstStartTag = False + + def processEndTag(self, token): + # Note the caching is done here rather than BoundMethodDispatcher as doing it there + # requires a circular reference to the Phase, and this ends up with a significant + # (CPython 2.7, 3.8) GC cost when parsing many short inputs + name = token["name"] + # In Py2, using `in` is quicker in general than try/except KeyError + # In Py3, `in` is quicker when there are few cache hits (typically short inputs) + if name in self.__endTagCache: + func = self.__endTagCache[name] + else: + func = self.__endTagCache[name] = self.endTagHandler[name] + # bound the cache size in case we get loads of unknown tags + while len(self.__endTagCache) > len(self.endTagHandler) * 1.1: + # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7 + self.__endTagCache.pop(next(iter(self.__endTagCache))) + return func(token) + + class InitialPhase(Phase): + __slots__ = tuple() + + def processSpaceCharacters(self, token): + pass + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processDoctype(self, token): + name = token["name"] + publicId = token["publicId"] + systemId = token["systemId"] + correct = token["correct"] + + if (name != "html" or publicId is not None or + systemId is not None and systemId != "about:legacy-compat"): + self.parser.parseError("unknown-doctype") + + if publicId is None: + publicId = "" + + self.tree.insertDoctype(token) + + if publicId != "": + publicId = publicId.translate(asciiUpper2Lower) + + if (not correct or token["name"] != "html" or + publicId.startswith( + ("+//silmaril//dtd html pro v0r11 19970101//", + "-//advasoft ltd//dtd html 3.0 aswedit + extensions//", + "-//as//dtd html 3.0 aswedit + extensions//", + "-//ietf//dtd html 2.0 level 1//", + "-//ietf//dtd html 2.0 level 2//", + "-//ietf//dtd html 2.0 strict level 1//", + "-//ietf//dtd html 2.0 strict level 2//", + "-//ietf//dtd html 2.0 strict//", + "-//ietf//dtd html 2.0//", + "-//ietf//dtd html 2.1e//", + "-//ietf//dtd html 3.0//", + "-//ietf//dtd html 3.2 final//", + "-//ietf//dtd html 3.2//", + "-//ietf//dtd html 3//", + "-//ietf//dtd html level 0//", + "-//ietf//dtd html level 1//", + "-//ietf//dtd html level 2//", + "-//ietf//dtd html level 3//", + "-//ietf//dtd html strict level 0//", + "-//ietf//dtd html strict level 1//", + "-//ietf//dtd html strict level 2//", + "-//ietf//dtd html strict level 3//", + "-//ietf//dtd html strict//", + "-//ietf//dtd html//", + "-//metrius//dtd metrius presentational//", + "-//microsoft//dtd internet explorer 2.0 html strict//", + "-//microsoft//dtd internet explorer 2.0 html//", + "-//microsoft//dtd internet explorer 2.0 tables//", + "-//microsoft//dtd internet explorer 3.0 html strict//", + "-//microsoft//dtd internet explorer 3.0 html//", + "-//microsoft//dtd internet explorer 3.0 tables//", + "-//netscape comm. corp.//dtd html//", + "-//netscape comm. corp.//dtd strict html//", + "-//o'reilly and associates//dtd html 2.0//", + "-//o'reilly and associates//dtd html extended 1.0//", + "-//o'reilly and associates//dtd html extended relaxed 1.0//", + "-//softquad software//dtd hotmetal pro 6.0::19990601::extensions to html 4.0//", + "-//softquad//dtd hotmetal pro 4.0::19971010::extensions to html 4.0//", + "-//spyglass//dtd html 2.0 extended//", + "-//sq//dtd html 2.0 hotmetal + extensions//", + "-//sun microsystems corp.//dtd hotjava html//", + "-//sun microsystems corp.//dtd hotjava strict html//", + "-//w3c//dtd html 3 1995-03-24//", + "-//w3c//dtd html 3.2 draft//", + "-//w3c//dtd html 3.2 final//", + "-//w3c//dtd html 3.2//", + "-//w3c//dtd html 3.2s draft//", + "-//w3c//dtd html 4.0 frameset//", + "-//w3c//dtd html 4.0 transitional//", + "-//w3c//dtd html experimental 19960712//", + "-//w3c//dtd html experimental 970421//", + "-//w3c//dtd w3 html//", + "-//w3o//dtd w3 html 3.0//", + "-//webtechs//dtd mozilla html 2.0//", + "-//webtechs//dtd mozilla html//")) or + publicId in ("-//w3o//dtd w3 html strict 3.0//en//", + "-/w3c/dtd html 4.0 transitional/en", + "html") or + publicId.startswith( + ("-//w3c//dtd html 4.01 frameset//", + "-//w3c//dtd html 4.01 transitional//")) and + systemId is None or + systemId and systemId.lower() == "http://www.ibm.com/data/dtd/v11/ibmxhtml1-transitional.dtd"): + self.parser.compatMode = "quirks" + elif (publicId.startswith( + ("-//w3c//dtd xhtml 1.0 frameset//", + "-//w3c//dtd xhtml 1.0 transitional//")) or + publicId.startswith( + ("-//w3c//dtd html 4.01 frameset//", + "-//w3c//dtd html 4.01 transitional//")) and + systemId is not None): + self.parser.compatMode = "limited quirks" + + self.parser.phase = self.parser.phases["beforeHtml"] + + def anythingElse(self): + self.parser.compatMode = "quirks" + self.parser.phase = self.parser.phases["beforeHtml"] + + def processCharacters(self, token): + self.parser.parseError("expected-doctype-but-got-chars") + self.anythingElse() + return token + + def processStartTag(self, token): + self.parser.parseError("expected-doctype-but-got-start-tag", + {"name": token["name"]}) + self.anythingElse() + return token + + def processEndTag(self, token): + self.parser.parseError("expected-doctype-but-got-end-tag", + {"name": token["name"]}) + self.anythingElse() + return token + + def processEOF(self): + self.parser.parseError("expected-doctype-but-got-eof") + self.anythingElse() + return True + + class BeforeHtmlPhase(Phase): + __slots__ = tuple() + + # helper methods + def insertHtmlElement(self): + self.tree.insertRoot(impliedTagToken("html", "StartTag")) + self.parser.phase = self.parser.phases["beforeHead"] + + # other + def processEOF(self): + self.insertHtmlElement() + return True + + def processComment(self, token): + self.tree.insertComment(token, self.tree.document) + + def processSpaceCharacters(self, token): + pass + + def processCharacters(self, token): + self.insertHtmlElement() + return token + + def processStartTag(self, token): + if token["name"] == "html": + self.parser.firstStartTag = True + self.insertHtmlElement() + return token + + def processEndTag(self, token): + if token["name"] not in ("head", "body", "html", "br"): + self.parser.parseError("unexpected-end-tag-before-html", + {"name": token["name"]}) + else: + self.insertHtmlElement() + return token + + class BeforeHeadPhase(Phase): + __slots__ = tuple() + + def processEOF(self): + self.startTagHead(impliedTagToken("head", "StartTag")) + return True + + def processSpaceCharacters(self, token): + pass + + def processCharacters(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagHead(self, token): + self.tree.insertElement(token) + self.tree.headPointer = self.tree.openElements[-1] + self.parser.phase = self.parser.phases["inHead"] + + def startTagOther(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def endTagImplyHead(self, token): + self.startTagHead(impliedTagToken("head", "StartTag")) + return token + + def endTagOther(self, token): + self.parser.parseError("end-tag-after-implied-root", + {"name": token["name"]}) + + startTagHandler = _utils.MethodDispatcher([ + ("html", startTagHtml), + ("head", startTagHead) + ]) + startTagHandler.default = startTagOther + + endTagHandler = _utils.MethodDispatcher([ + (("head", "body", "html", "br"), endTagImplyHead) + ]) + endTagHandler.default = endTagOther + + class InHeadPhase(Phase): + __slots__ = tuple() + + # the real thing + def processEOF(self): + self.anythingElse() + return True + + def processCharacters(self, token): + self.anythingElse() + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagHead(self, token): + self.parser.parseError("two-heads-are-not-better-than-one") + + def startTagBaseLinkCommand(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + def startTagMeta(self, token): + self.tree.insertElement(token) + self.tree.openElements.pop() + token["selfClosingAcknowledged"] = True + + attributes = token["data"] + if self.parser.tokenizer.stream.charEncoding[1] == "tentative": + if "charset" in attributes: + self.parser.tokenizer.stream.changeEncoding(attributes["charset"]) + elif ("content" in attributes and + "http-equiv" in attributes and + attributes["http-equiv"].lower() == "content-type"): + # Encoding it as UTF-8 here is a hack, as really we should pass + # the abstract Unicode string, and just use the + # ContentAttrParser on that, but using UTF-8 allows all chars + # to be encoded and as a ASCII-superset works. + data = _inputstream.EncodingBytes(attributes["content"].encode("utf-8")) + parser = _inputstream.ContentAttrParser(data) + codec = parser.parse() + self.parser.tokenizer.stream.changeEncoding(codec) + + def startTagTitle(self, token): + self.parser.parseRCDataRawtext(token, "RCDATA") + + def startTagNoFramesStyle(self, token): + # Need to decide whether to implement the scripting-disabled case + self.parser.parseRCDataRawtext(token, "RAWTEXT") + + def startTagNoscript(self, token): + if self.parser.scripting: + self.parser.parseRCDataRawtext(token, "RAWTEXT") + else: + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inHeadNoscript"] + + def startTagScript(self, token): + self.tree.insertElement(token) + self.parser.tokenizer.state = self.parser.tokenizer.scriptDataState + self.parser.originalPhase = self.parser.phase + self.parser.phase = self.parser.phases["text"] + + def startTagOther(self, token): + self.anythingElse() + return token + + def endTagHead(self, token): + node = self.parser.tree.openElements.pop() + assert node.name == "head", "Expected head got %s" % node.name + self.parser.phase = self.parser.phases["afterHead"] + + def endTagHtmlBodyBr(self, token): + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + self.endTagHead(impliedTagToken("head")) + + startTagHandler = _utils.MethodDispatcher([ + ("html", startTagHtml), + ("title", startTagTitle), + (("noframes", "style"), startTagNoFramesStyle), + ("noscript", startTagNoscript), + ("script", startTagScript), + (("base", "basefont", "bgsound", "command", "link"), + startTagBaseLinkCommand), + ("meta", startTagMeta), + ("head", startTagHead) + ]) + startTagHandler.default = startTagOther + + endTagHandler = _utils.MethodDispatcher([ + ("head", endTagHead), + (("br", "html", "body"), endTagHtmlBodyBr) + ]) + endTagHandler.default = endTagOther + + class InHeadNoscriptPhase(Phase): + __slots__ = tuple() + + def processEOF(self): + self.parser.parseError("eof-in-head-noscript") + self.anythingElse() + return True + + def processComment(self, token): + return self.parser.phases["inHead"].processComment(token) + + def processCharacters(self, token): + self.parser.parseError("char-in-head-noscript") + self.anythingElse() + return token + + def processSpaceCharacters(self, token): + return self.parser.phases["inHead"].processSpaceCharacters(token) + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagBaseLinkCommand(self, token): + return self.parser.phases["inHead"].processStartTag(token) + + def startTagHeadNoscript(self, token): + self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) + + def startTagOther(self, token): + self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) + self.anythingElse() + return token + + def endTagNoscript(self, token): + node = self.parser.tree.openElements.pop() + assert node.name == "noscript", "Expected noscript got %s" % node.name + self.parser.phase = self.parser.phases["inHead"] + + def endTagBr(self, token): + self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]}) + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + # Caller must raise parse error first! + self.endTagNoscript(impliedTagToken("noscript")) + + startTagHandler = _utils.MethodDispatcher([ + ("html", startTagHtml), + (("basefont", "bgsound", "link", "meta", "noframes", "style"), startTagBaseLinkCommand), + (("head", "noscript"), startTagHeadNoscript), + ]) + startTagHandler.default = startTagOther + + endTagHandler = _utils.MethodDispatcher([ + ("noscript", endTagNoscript), + ("br", endTagBr), + ]) + endTagHandler.default = endTagOther + + class AfterHeadPhase(Phase): + __slots__ = tuple() + + def processEOF(self): + self.anythingElse() + return True + + def processCharacters(self, token): + self.anythingElse() + return token + + def startTagHtml(self, token): + return self.parser.phases["inBody"].processStartTag(token) + + def startTagBody(self, token): + self.parser.framesetOK = False + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inBody"] + + def startTagFrameset(self, token): + self.tree.insertElement(token) + self.parser.phase = self.parser.phases["inFrameset"] + + def startTagFromHead(self, token): + self.parser.parseError("unexpected-start-tag-out-of-my-head", + {"name": token["name"]}) + self.tree.openElements.append(self.tree.headPointer) + self.parser.phases["inHead"].processStartTag(token) + for node in self.tree.openElements[::-1]: + if node.name == "head": + self.tree.openElements.remove(node) + break + + def startTagHead(self, token): + self.parser.parseError("unexpected-start-tag", {"name": token["name"]}) + + def startTagOther(self, token): + self.anythingElse() + return token + + def endTagHtmlBodyBr(self, token): + self.anythingElse() + return token + + def endTagOther(self, token): + self.parser.parseError("unexpected-end-tag", {"name": token["name"]}) + + def anythingElse(self): + self.tree.insertElement(impliedTagToken("body", "StartTag")) + self.parser.phase = self.parser.phases["inBody"] + self.parser.framesetOK = True + + startTagHandler = _utils.MethodDispatcher([ + ("html", startTagHtml), + ("body", startTagBody), + ("frameset", startTagFrameset), + (("base", "basefont", "bgsound", "link", "meta", "noframes", "script", + "style", "title"), + startTagFromHead), + ("head", startTagHead) + ]) + startTagHandler.default = startTagOther + endTagHandler = _utils.MethodDispatcher([(("body", "html", "br"), + endTagHtmlBodyBr)]) + endTagHandler.default = endTagOther + + class InBodyPhase(Phase): + # http://www.whatwg.org/specs/web-apps/current-work/#parsing-main-inbody + # the really-really-really-very crazy mode + __slots__ = ("processSpaceCharacters",) + + def __init__(self, *args, **kwargs): + super(InBodyPhase, self).__init__(*args, **kwargs) + # Set this to the default handler + self.processSpaceCharacters = self.processSpaceCharactersNonPre + + def isMatchingFormattingElement(self, node1, node2): + return (node1.name == node2.name and + node1.namespace == node2.namespace and + node1.attributes == node2.attributes) + + # helper + def addFormattingElement(self, token): + self.tree.insertElement(token) + element = self.tree.openElements[-1] + + matchingElements = [] + for node in self.tree.activeFormattingElements[::-1]: + if node is Marker: + break + elif self.isMatchingFormattingElement(node, element): + matchingElements.append(node) + + assert len(matchingElements) <= 3 + if len(matchingElements) == 3: + self.tree.activeFormattingElements.remove(matchingElements[-1]) + self.tree.activeFormattingElements.append(element) + + # the real deal + def processEOF(self): + allowed_elements = frozenset(("dd", "dt", "li", "p", "tbody", "td", + "tfoot", "th", "thead", "tr", "body", + "html")) + for node in self.tree.openElements[::-1]: + if node.name not in allowed_elements: + self.parser.parseError("expected-closing-tag-but-got-eof") + break + # Stop parsing + + def processSpaceCharactersDropNewline(self, token): + # Sometimes (start of
, , and 
+

Charset Detection, for Everyone 👋

+
+ The debugger caught an exception in your WSGI application. You can now + look at the traceback which led to the error. + If you enable JavaScript you can also use additional features such as code + execution (if the evalex feature is enabled), automatic pasting of the + exceptions and much more. +
+""" + + FOOTER + + """ + +""" +) + +CONSOLE_HTML = ( + HEADER + + """\ +

Interactive Console

+
+In this console you can execute Python expressions in the context of the +application. The initial namespace was created by the debugger automatically. +
+
The Console requires JavaScript.
+""" + + FOOTER +) + +SUMMARY_HTML = """\ +
+ %(title)s +
    %(frames)s
+ %(description)s +
+""" + +FRAME_HTML = """\ +
+

File "%(filename)s", + line %(lineno)s, + in %(function_name)s

+
%(lines)s
+
+""" + +SOURCE_LINE_HTML = """\ + + %(lineno)s + %(code)s + +""" + + +def render_console_html(secret: str, evalex_trusted: bool = True) -> str: + return CONSOLE_HTML % { + "evalex": "true", + "evalex_trusted": "true" if evalex_trusted else "false", + "console": "true", + "title": "Console", + "secret": secret, + "traceback_id": -1, + } + + +def get_current_traceback( + ignore_system_exceptions: bool = False, + show_hidden_frames: bool = False, + skip: int = 0, +) -> "Traceback": + """Get the current exception info as `Traceback` object. Per default + calling this method will reraise system exceptions such as generator exit, + system exit or others. This behavior can be disabled by passing `False` + to the function as first parameter. + """ + info = t.cast( + t.Tuple[t.Type[BaseException], BaseException, TracebackType], sys.exc_info() + ) + exc_type, exc_value, tb = info + + if ignore_system_exceptions and exc_type in { + SystemExit, + KeyboardInterrupt, + GeneratorExit, + }: + raise + for _ in range(skip): + if tb.tb_next is None: + break + tb = tb.tb_next + tb = Traceback(exc_type, exc_value, tb) + if not show_hidden_frames: + tb.filter_hidden_frames() + return tb + + +class Line: + """Helper for the source renderer.""" + + __slots__ = ("lineno", "code", "in_frame", "current") + + def __init__(self, lineno: int, code: str) -> None: + self.lineno = lineno + self.code = code + self.in_frame = False + self.current = False + + @property + def classes(self) -> t.List[str]: + rv = ["line"] + if self.in_frame: + rv.append("in-frame") + if self.current: + rv.append("current") + return rv + + def render(self) -> str: + return SOURCE_LINE_HTML % { + "classes": " ".join(self.classes), + "lineno": self.lineno, + "code": escape(self.code), + } + + +class Traceback: + """Wraps a traceback.""" + + def __init__( + self, + exc_type: t.Type[BaseException], + exc_value: BaseException, + tb: TracebackType, + ) -> None: + self.exc_type = exc_type + self.exc_value = exc_value + self.tb = tb + + exception_type = exc_type.__name__ + if exc_type.__module__ not in {"builtins", "__builtin__", "exceptions"}: + exception_type = f"{exc_type.__module__}.{exception_type}" + self.exception_type = exception_type + + self.groups = [] + memo = set() + while True: + self.groups.append(Group(exc_type, exc_value, tb)) + memo.add(id(exc_value)) + exc_value = exc_value.__cause__ or exc_value.__context__ # type: ignore + if exc_value is None or id(exc_value) in memo: + break + exc_type = type(exc_value) + tb = exc_value.__traceback__ # type: ignore + self.groups.reverse() + self.frames = [frame for group in self.groups for frame in group.frames] + + def filter_hidden_frames(self) -> None: + """Remove the frames according to the paste spec.""" + for group in self.groups: + group.filter_hidden_frames() + + self.frames[:] = [frame for group in self.groups for frame in group.frames] + + @property + def is_syntax_error(self) -> bool: + """Is it a syntax error?""" + return isinstance(self.exc_value, SyntaxError) + + @property + def exception(self) -> str: + """String representation of the final exception.""" + return self.groups[-1].exception + + def log(self, logfile: t.Optional[t.IO[str]] = None) -> None: + """Log the ASCII traceback into a file object.""" + if logfile is None: + logfile = sys.stderr + tb = f"{self.plaintext.rstrip()}\n" + logfile.write(tb) + + def render_summary(self, include_title: bool = True) -> str: + """Render the traceback for the interactive console.""" + title = "" + classes = ["traceback"] + if not self.frames: + classes.append("noframe-traceback") + frames = [] + else: + library_frames = sum(frame.is_library for frame in self.frames) + mark_lib = 0 < library_frames < len(self.frames) + frames = [group.render(mark_lib=mark_lib) for group in self.groups] + + if include_title: + if self.is_syntax_error: + title = "Syntax Error" + else: + title = "Traceback (most recent call last):" + + if self.is_syntax_error: + description = f"
{escape(self.exception)}
" + else: + description = f"
{escape(self.exception)}
" + + return SUMMARY_HTML % { + "classes": " ".join(classes), + "title": f"

{title if title else ''}

", + "frames": "\n".join(frames), + "description": description, + } + + def render_full( + self, + evalex: bool = False, + secret: t.Optional[str] = None, + evalex_trusted: bool = True, + ) -> str: + """Render the Full HTML page with the traceback info.""" + exc = escape(self.exception) + return PAGE_HTML % { + "evalex": "true" if evalex else "false", + "evalex_trusted": "true" if evalex_trusted else "false", + "console": "false", + "title": exc, + "exception": exc, + "exception_type": escape(self.exception_type), + "summary": self.render_summary(include_title=False), + "plaintext": escape(self.plaintext), + "plaintext_cs": re.sub("-{2,}", "-", self.plaintext), + "traceback_id": self.id, + "secret": secret, + } + + @cached_property + def plaintext(self) -> str: + return "\n".join([group.render_text() for group in self.groups]) + + @property + def id(self) -> int: + return id(self) + + +class Group: + """A group of frames for an exception in a traceback. If the + exception has a ``__cause__`` or ``__context__``, there are multiple + exception groups. + """ + + def __init__( + self, + exc_type: t.Type[BaseException], + exc_value: BaseException, + tb: TracebackType, + ) -> None: + self.exc_type = exc_type + self.exc_value = exc_value + self.info = None + if exc_value.__cause__ is not None: + self.info = ( + "The above exception was the direct cause of the following exception" + ) + elif exc_value.__context__ is not None: + self.info = ( + "During handling of the above exception, another exception occurred" + ) + + self.frames = [] + while tb is not None: + self.frames.append(Frame(exc_type, exc_value, tb)) + tb = tb.tb_next # type: ignore + + def filter_hidden_frames(self) -> None: + # An exception may not have a traceback to filter frames, such + # as one re-raised from ProcessPoolExecutor. + if not self.frames: + return + + new_frames: t.List[Frame] = [] + hidden = False + + for frame in self.frames: + hide = frame.hide + if hide in ("before", "before_and_this"): + new_frames = [] + hidden = False + if hide == "before_and_this": + continue + elif hide in ("reset", "reset_and_this"): + hidden = False + if hide == "reset_and_this": + continue + elif hide in ("after", "after_and_this"): + hidden = True + if hide == "after_and_this": + continue + elif hide or hidden: + continue + new_frames.append(frame) + + # if we only have one frame and that frame is from the codeop + # module, remove it. + if len(new_frames) == 1 and self.frames[0].module == "codeop": + del self.frames[:] + + # if the last frame is missing something went terrible wrong :( + elif self.frames[-1] in new_frames: + self.frames[:] = new_frames + + @property + def exception(self) -> str: + """String representation of the exception.""" + buf = traceback.format_exception_only(self.exc_type, self.exc_value) + rv = "".join(buf).strip() + return _to_str(rv, "utf-8", "replace") + + def render(self, mark_lib: bool = True) -> str: + out = [] + if self.info is not None: + out.append(f'
  • {self.info}:
    ') + for frame in self.frames: + title = f' title="{escape(frame.info)}"' if frame.info else "" + out.append(f"{frame.render(mark_lib=mark_lib)}") + return "\n".join(out) + + def render_text(self) -> str: + out = [] + if self.info is not None: + out.append(f"\n{self.info}:\n") + out.append("Traceback (most recent call last):") + for frame in self.frames: + out.append(frame.render_text()) + out.append(self.exception) + return "\n".join(out) + + +class Frame: + """A single frame in a traceback.""" + + def __init__( + self, + exc_type: t.Type[BaseException], + exc_value: BaseException, + tb: TracebackType, + ) -> None: + self.lineno = tb.tb_lineno + self.function_name = tb.tb_frame.f_code.co_name + self.locals = tb.tb_frame.f_locals + self.globals = tb.tb_frame.f_globals + + fn = inspect.getsourcefile(tb) or inspect.getfile(tb) + if fn[-4:] in (".pyo", ".pyc"): + fn = fn[:-1] + # if it's a file on the file system resolve the real filename. + if os.path.isfile(fn): + fn = os.path.realpath(fn) + self.filename = _to_str(fn, get_filesystem_encoding()) + self.module = self.globals.get("__name__", self.locals.get("__name__")) + self.loader = self.globals.get("__loader__", self.locals.get("__loader__")) + self.code = tb.tb_frame.f_code + + # support for paste's traceback extensions + self.hide = self.locals.get("__traceback_hide__", False) + info = self.locals.get("__traceback_info__") + if info is not None: + info = _to_str(info, "utf-8", "replace") + self.info = info + + def render(self, mark_lib: bool = True) -> str: + """Render a single frame in a traceback.""" + return FRAME_HTML % { + "id": self.id, + "filename": escape(self.filename), + "lineno": self.lineno, + "function_name": escape(self.function_name), + "lines": self.render_line_context(), + "library": "library" if mark_lib and self.is_library else "", + } + + @cached_property + def is_library(self) -> bool: + return any( + self.filename.startswith(os.path.realpath(path)) + for path in sysconfig.get_paths().values() + ) + + def render_text(self) -> str: + return ( + f' File "{self.filename}", line {self.lineno}, in {self.function_name}\n' + f" {self.current_line.strip()}" + ) + + def render_line_context(self) -> str: + before, current, after = self.get_context_lines() + rv = [] + + def render_line(line: str, cls: str) -> None: + line = line.expandtabs().rstrip() + stripped_line = line.strip() + prefix = len(line) - len(stripped_line) + rv.append( + f'
    {" " * prefix}'
    +                f"{escape(stripped_line) if stripped_line else ' '}
    " + ) + + for line in before: + render_line(line, "before") + render_line(current, "current") + for line in after: + render_line(line, "after") + + return "\n".join(rv) + + def get_annotated_lines(self) -> t.List[Line]: + """Helper function that returns lines with extra information.""" + lines = [Line(idx + 1, x) for idx, x in enumerate(self.sourcelines)] + + # find function definition and mark lines + if hasattr(self.code, "co_firstlineno"): + lineno = self.code.co_firstlineno - 1 + while lineno > 0: + if _funcdef_re.match(lines[lineno].code): + break + lineno -= 1 + try: + offset = len(inspect.getblock([f"{x.code}\n" for x in lines[lineno:]])) + except TokenError: + offset = 0 + for line in lines[lineno : lineno + offset]: + line.in_frame = True + + # mark current line + try: + lines[self.lineno - 1].current = True + except IndexError: + pass + + return lines + + def eval(self, code: t.Union[str, CodeType], mode: str = "single") -> t.Any: + """Evaluate code in the context of the frame.""" + if isinstance(code, str): + code = compile(code, "", mode) + return eval(code, self.globals, self.locals) + + @cached_property + def sourcelines(self) -> t.List[str]: + """The sourcecode of the file as list of strings.""" + # get sourcecode from loader or file + source = None + if self.loader is not None: + try: + if hasattr(self.loader, "get_source"): + source = self.loader.get_source(self.module) + elif hasattr(self.loader, "get_source_by_code"): + source = self.loader.get_source_by_code(self.code) + except Exception: + # we munch the exception so that we don't cause troubles + # if the loader is broken. + pass + + if source is None: + try: + with open(self.filename, mode="rb") as f: + source = f.read() + except OSError: + return [] + + # already str? return right away + if isinstance(source, str): + return source.splitlines() + + charset = "utf-8" + if source.startswith(codecs.BOM_UTF8): + source = source[3:] + else: + for idx, match in enumerate(_line_re.finditer(source)): + coding_match = _coding_re.search(match.group()) + if coding_match is not None: + charset = coding_match.group(1).decode("utf-8") + break + if idx > 1: + break + + # on broken cookies we fall back to utf-8 too + charset = _to_str(charset) + try: + codecs.lookup(charset) + except LookupError: + charset = "utf-8" + + return source.decode(charset, "replace").splitlines() + + def get_context_lines( + self, context: int = 5 + ) -> t.Tuple[t.List[str], str, t.List[str]]: + before = self.sourcelines[self.lineno - context - 1 : self.lineno - 1] + past = self.sourcelines[self.lineno : self.lineno + context] + return (before, self.current_line, past) + + @property + def current_line(self) -> str: + try: + return self.sourcelines[self.lineno - 1] + except IndexError: + return "" + + @cached_property + def console(self) -> Console: + return Console(self.globals, self.locals) + + @property + def id(self) -> int: + return id(self) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/exceptions.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/exceptions.py new file mode 100644 index 00000000..16c3964d --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/exceptions.py @@ -0,0 +1,943 @@ +"""Implements a number of Python exceptions which can be raised from within +a view to trigger a standard HTTP non-200 response. + +Usage Example +------------- + +.. code-block:: python + + from werkzeug.wrappers.request import Request + from werkzeug.exceptions import HTTPException, NotFound + + def view(request): + raise NotFound() + + @Request.application + def application(request): + try: + return view(request) + except HTTPException as e: + return e + +As you can see from this example those exceptions are callable WSGI +applications. However, they are not Werkzeug response objects. You +can get a response object by calling ``get_response()`` on a HTTP +exception. + +Keep in mind that you may have to pass an environ (WSGI) or scope +(ASGI) to ``get_response()`` because some errors fetch additional +information relating to the request. + +If you want to hook in a different exception page to say, a 404 status +code, you can add a second except for a specific subclass of an error: + +.. code-block:: python + + @Request.application + def application(request): + try: + return view(request) + except NotFound as e: + return not_found(request) + except HTTPException as e: + return e + +""" +import sys +import typing as t +import warnings +from datetime import datetime +from html import escape + +from ._internal import _get_environ + +if t.TYPE_CHECKING: + import typing_extensions as te + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIEnvironment + from .datastructures import WWWAuthenticate + from .sansio.response import Response + from .wrappers.response import Response as WSGIResponse # noqa: F401 + + +class HTTPException(Exception): + """The base class for all HTTP exceptions. This exception can be called as a WSGI + application to render a default error page or you can catch the subclasses + of it independently and render nicer error messages. + """ + + code: t.Optional[int] = None + description: t.Optional[str] = None + + def __init__( + self, + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + ) -> None: + super().__init__() + if description is not None: + self.description = description + self.response = response + + @classmethod + def wrap( + cls, exception: t.Type[BaseException], name: t.Optional[str] = None + ) -> t.Type["HTTPException"]: + """Create an exception that is a subclass of the calling HTTP + exception and the ``exception`` argument. + + The first argument to the class will be passed to the + wrapped ``exception``, the rest to the HTTP exception. If + ``e.args`` is not empty and ``e.show_exception`` is ``True``, + the wrapped exception message is added to the HTTP error + description. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Create a subclass manually + instead. + + .. versionchanged:: 0.15.5 + The ``show_exception`` attribute controls whether the + description includes the wrapped exception message. + + .. versionchanged:: 0.15.0 + The description includes the wrapped exception message. + """ + warnings.warn( + "'HTTPException.wrap' is deprecated and will be removed in" + " Werkzeug 2.1. Create a subclass manually instead.", + DeprecationWarning, + stacklevel=2, + ) + + class newcls(cls, exception): # type: ignore + _description = cls.description + show_exception = False + + def __init__( + self, arg: t.Optional[t.Any] = None, *args: t.Any, **kwargs: t.Any + ) -> None: + super().__init__(*args, **kwargs) + + if arg is None: + exception.__init__(self) + else: + exception.__init__(self, arg) + + @property + def description(self) -> str: + if self.show_exception: + return ( + f"{self._description}\n" + f"{exception.__name__}: {exception.__str__(self)}" + ) + + return self._description # type: ignore + + @description.setter + def description(self, value: str) -> None: + self._description = value + + newcls.__module__ = sys._getframe(1).f_globals["__name__"] + name = name or cls.__name__ + exception.__name__ + newcls.__name__ = newcls.__qualname__ = name + return newcls + + @property + def name(self) -> str: + """The status name.""" + from .http import HTTP_STATUS_CODES + + return HTTP_STATUS_CODES.get(self.code, "Unknown Error") # type: ignore + + def get_description( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> str: + """Get the description.""" + if self.description is None: + description = "" + elif not isinstance(self.description, str): + description = str(self.description) + else: + description = self.description + + description = escape(description).replace("\n", "
    ") + return f"

    {description}

    " + + def get_body( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> str: + """Get the HTML body.""" + return ( + '\n' + f"{self.code} {escape(self.name)}\n" + f"

    {escape(self.name)}

    \n" + f"{self.get_description(environ)}\n" + ) + + def get_headers( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> t.List[t.Tuple[str, str]]: + """Get a list of headers.""" + return [("Content-Type", "text/html; charset=utf-8")] + + def get_response( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> "Response": + """Get a response object. If one was passed to the exception + it's returned directly. + + :param environ: the optional environ for the request. This + can be used to modify the response depending + on how the request looked like. + :return: a :class:`Response` object or a subclass thereof. + """ + from .wrappers.response import Response as WSGIResponse # noqa: F811 + + if self.response is not None: + return self.response + if environ is not None: + environ = _get_environ(environ) + headers = self.get_headers(environ, scope) + return WSGIResponse(self.get_body(environ, scope), self.code, headers) + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + """Call the exception as WSGI application. + + :param environ: the WSGI environment. + :param start_response: the response callable provided by the WSGI + server. + """ + response = t.cast("WSGIResponse", self.get_response(environ)) + return response(environ, start_response) + + def __str__(self) -> str: + code = self.code if self.code is not None else "???" + return f"{code} {self.name}: {self.description}" + + def __repr__(self) -> str: + code = self.code if self.code is not None else "???" + return f"<{type(self).__name__} '{code}: {self.name}'>" + + +class BadRequest(HTTPException): + """*400* `Bad Request` + + Raise if the browser sends something to the application the application + or server cannot handle. + """ + + code = 400 + description = ( + "The browser (or proxy) sent a request that this server could " + "not understand." + ) + + +class BadRequestKeyError(BadRequest, KeyError): + """An exception that is used to signal both a :exc:`KeyError` and a + :exc:`BadRequest`. Used by many of the datastructures. + """ + + _description = BadRequest.description + #: Show the KeyError along with the HTTP error message in the + #: response. This should be disabled in production, but can be + #: useful in a debug mode. + show_exception = False + + def __init__(self, arg: t.Optional[str] = None, *args: t.Any, **kwargs: t.Any): + super().__init__(*args, **kwargs) + + if arg is None: + KeyError.__init__(self) + else: + KeyError.__init__(self, arg) + + @property # type: ignore + def description(self) -> str: # type: ignore + if self.show_exception: + return ( + f"{self._description}\n" + f"{KeyError.__name__}: {KeyError.__str__(self)}" + ) + + return self._description + + @description.setter + def description(self, value: str) -> None: + self._description = value + + +class ClientDisconnected(BadRequest): + """Internal exception that is raised if Werkzeug detects a disconnected + client. Since the client is already gone at that point attempting to + send the error message to the client might not work and might ultimately + result in another exception in the server. Mainly this is here so that + it is silenced by default as far as Werkzeug is concerned. + + Since disconnections cannot be reliably detected and are unspecified + by WSGI to a large extent this might or might not be raised if a client + is gone. + + .. versionadded:: 0.8 + """ + + +class SecurityError(BadRequest): + """Raised if something triggers a security error. This is otherwise + exactly like a bad request error. + + .. versionadded:: 0.9 + """ + + +class BadHost(BadRequest): + """Raised if the submitted host is badly formatted. + + .. versionadded:: 0.11.2 + """ + + +class Unauthorized(HTTPException): + """*401* ``Unauthorized`` + + Raise if the user is not authorized to access a resource. + + The ``www_authenticate`` argument should be used to set the + ``WWW-Authenticate`` header. This is used for HTTP basic auth and + other schemes. Use :class:`~werkzeug.datastructures.WWWAuthenticate` + to create correctly formatted values. Strictly speaking a 401 + response is invalid if it doesn't provide at least one value for + this header, although real clients typically don't care. + + :param description: Override the default message used for the body + of the response. + :param www-authenticate: A single value, or list of values, for the + WWW-Authenticate header(s). + + .. versionchanged:: 2.0 + Serialize multiple ``www_authenticate`` items into multiple + ``WWW-Authenticate`` headers, rather than joining them + into a single value, for better interoperability. + + .. versionchanged:: 0.15.3 + If the ``www_authenticate`` argument is not set, the + ``WWW-Authenticate`` header is not set. + + .. versionchanged:: 0.15.3 + The ``response`` argument was restored. + + .. versionchanged:: 0.15.1 + ``description`` was moved back as the first argument, restoring + its previous position. + + .. versionchanged:: 0.15.0 + ``www_authenticate`` was added as the first argument, ahead of + ``description``. + """ + + code = 401 + description = ( + "The server could not verify that you are authorized to access" + " the URL requested. You either supplied the wrong credentials" + " (e.g. a bad password), or your browser doesn't understand" + " how to supply the credentials required." + ) + + def __init__( + self, + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + www_authenticate: t.Optional[ + t.Union["WWWAuthenticate", t.Iterable["WWWAuthenticate"]] + ] = None, + ) -> None: + super().__init__(description, response) + + from .datastructures import WWWAuthenticate + + if isinstance(www_authenticate, WWWAuthenticate): + www_authenticate = (www_authenticate,) + + self.www_authenticate = www_authenticate + + def get_headers( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> t.List[t.Tuple[str, str]]: + headers = super().get_headers(environ, scope) + if self.www_authenticate: + headers.extend(("WWW-Authenticate", str(x)) for x in self.www_authenticate) + return headers + + +class Forbidden(HTTPException): + """*403* `Forbidden` + + Raise if the user doesn't have the permission for the requested resource + but was authenticated. + """ + + code = 403 + description = ( + "You don't have the permission to access the requested" + " resource. It is either read-protected or not readable by the" + " server." + ) + + +class NotFound(HTTPException): + """*404* `Not Found` + + Raise if a resource does not exist and never existed. + """ + + code = 404 + description = ( + "The requested URL was not found on the server. If you entered" + " the URL manually please check your spelling and try again." + ) + + +class MethodNotAllowed(HTTPException): + """*405* `Method Not Allowed` + + Raise if the server used a method the resource does not handle. For + example `POST` if the resource is view only. Especially useful for REST. + + The first argument for this exception should be a list of allowed methods. + Strictly speaking the response would be invalid if you don't provide valid + methods in the header which you can do with that list. + """ + + code = 405 + description = "The method is not allowed for the requested URL." + + def __init__( + self, + valid_methods: t.Optional[t.Iterable[str]] = None, + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + ) -> None: + """Takes an optional list of valid http methods + starting with werkzeug 0.3 the list will be mandatory.""" + super().__init__(description=description, response=response) + self.valid_methods = valid_methods + + def get_headers( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> t.List[t.Tuple[str, str]]: + headers = super().get_headers(environ, scope) + if self.valid_methods: + headers.append(("Allow", ", ".join(self.valid_methods))) + return headers + + +class NotAcceptable(HTTPException): + """*406* `Not Acceptable` + + Raise if the server can't return any content conforming to the + `Accept` headers of the client. + """ + + code = 406 + description = ( + "The resource identified by the request is only capable of" + " generating response entities which have content" + " characteristics not acceptable according to the accept" + " headers sent in the request." + ) + + +class RequestTimeout(HTTPException): + """*408* `Request Timeout` + + Raise to signalize a timeout. + """ + + code = 408 + description = ( + "The server closed the network connection because the browser" + " didn't finish the request within the specified time." + ) + + +class Conflict(HTTPException): + """*409* `Conflict` + + Raise to signal that a request cannot be completed because it conflicts + with the current state on the server. + + .. versionadded:: 0.7 + """ + + code = 409 + description = ( + "A conflict happened while processing the request. The" + " resource might have been modified while the request was being" + " processed." + ) + + +class Gone(HTTPException): + """*410* `Gone` + + Raise if a resource existed previously and went away without new location. + """ + + code = 410 + description = ( + "The requested URL is no longer available on this server and" + " there is no forwarding address. If you followed a link from a" + " foreign page, please contact the author of this page." + ) + + +class LengthRequired(HTTPException): + """*411* `Length Required` + + Raise if the browser submitted data but no ``Content-Length`` header which + is required for the kind of processing the server does. + """ + + code = 411 + description = ( + "A request with this method requires a valid Content-" + "Length header." + ) + + +class PreconditionFailed(HTTPException): + """*412* `Precondition Failed` + + Status code used in combination with ``If-Match``, ``If-None-Match``, or + ``If-Unmodified-Since``. + """ + + code = 412 + description = ( + "The precondition on the request for the URL failed positive evaluation." + ) + + +class RequestEntityTooLarge(HTTPException): + """*413* `Request Entity Too Large` + + The status code one should return if the data submitted exceeded a given + limit. + """ + + code = 413 + description = "The data value transmitted exceeds the capacity limit." + + +class RequestURITooLarge(HTTPException): + """*414* `Request URI Too Large` + + Like *413* but for too long URLs. + """ + + code = 414 + description = ( + "The length of the requested URL exceeds the capacity limit for" + " this server. The request cannot be processed." + ) + + +class UnsupportedMediaType(HTTPException): + """*415* `Unsupported Media Type` + + The status code returned if the server is unable to handle the media type + the client transmitted. + """ + + code = 415 + description = ( + "The server does not support the media type transmitted in the request." + ) + + +class RequestedRangeNotSatisfiable(HTTPException): + """*416* `Requested Range Not Satisfiable` + + The client asked for an invalid part of the file. + + .. versionadded:: 0.7 + """ + + code = 416 + description = "The server cannot provide the requested range." + + def __init__( + self, + length: t.Optional[int] = None, + units: str = "bytes", + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + ) -> None: + """Takes an optional `Content-Range` header value based on ``length`` + parameter. + """ + super().__init__(description=description, response=response) + self.length = length + self.units = units + + def get_headers( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> t.List[t.Tuple[str, str]]: + headers = super().get_headers(environ, scope) + if self.length is not None: + headers.append(("Content-Range", f"{self.units} */{self.length}")) + return headers + + +class ExpectationFailed(HTTPException): + """*417* `Expectation Failed` + + The server cannot meet the requirements of the Expect request-header. + + .. versionadded:: 0.7 + """ + + code = 417 + description = "The server could not meet the requirements of the Expect header" + + +class ImATeapot(HTTPException): + """*418* `I'm a teapot` + + The server should return this if it is a teapot and someone attempted + to brew coffee with it. + + .. versionadded:: 0.7 + """ + + code = 418 + description = "This server is a teapot, not a coffee machine" + + +class UnprocessableEntity(HTTPException): + """*422* `Unprocessable Entity` + + Used if the request is well formed, but the instructions are otherwise + incorrect. + """ + + code = 422 + description = ( + "The request was well-formed but was unable to be followed due" + " to semantic errors." + ) + + +class Locked(HTTPException): + """*423* `Locked` + + Used if the resource that is being accessed is locked. + """ + + code = 423 + description = "The resource that is being accessed is locked." + + +class FailedDependency(HTTPException): + """*424* `Failed Dependency` + + Used if the method could not be performed on the resource + because the requested action depended on another action and that action failed. + """ + + code = 424 + description = ( + "The method could not be performed on the resource because the" + " requested action depended on another action and that action" + " failed." + ) + + +class PreconditionRequired(HTTPException): + """*428* `Precondition Required` + + The server requires this request to be conditional, typically to prevent + the lost update problem, which is a race condition between two or more + clients attempting to update a resource through PUT or DELETE. By requiring + each client to include a conditional header ("If-Match" or "If-Unmodified- + Since") with the proper value retained from a recent GET request, the + server ensures that each client has at least seen the previous revision of + the resource. + """ + + code = 428 + description = ( + "This request is required to be conditional; try using" + ' "If-Match" or "If-Unmodified-Since".' + ) + + +class _RetryAfter(HTTPException): + """Adds an optional ``retry_after`` parameter which will set the + ``Retry-After`` header. May be an :class:`int` number of seconds or + a :class:`~datetime.datetime`. + """ + + def __init__( + self, + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + retry_after: t.Optional[t.Union[datetime, int]] = None, + ) -> None: + super().__init__(description, response) + self.retry_after = retry_after + + def get_headers( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> t.List[t.Tuple[str, str]]: + headers = super().get_headers(environ, scope) + + if self.retry_after: + if isinstance(self.retry_after, datetime): + from .http import http_date + + value = http_date(self.retry_after) + else: + value = str(self.retry_after) + + headers.append(("Retry-After", value)) + + return headers + + +class TooManyRequests(_RetryAfter): + """*429* `Too Many Requests` + + The server is limiting the rate at which this user receives + responses, and this request exceeds that rate. (The server may use + any convenient method to identify users and their request rates). + The server may include a "Retry-After" header to indicate how long + the user should wait before retrying. + + :param retry_after: If given, set the ``Retry-After`` header to this + value. May be an :class:`int` number of seconds or a + :class:`~datetime.datetime`. + + .. versionchanged:: 1.0 + Added ``retry_after`` parameter. + """ + + code = 429 + description = "This user has exceeded an allotted request count. Try again later." + + +class RequestHeaderFieldsTooLarge(HTTPException): + """*431* `Request Header Fields Too Large` + + The server refuses to process the request because the header fields are too + large. One or more individual fields may be too large, or the set of all + headers is too large. + """ + + code = 431 + description = "One or more header fields exceeds the maximum size." + + +class UnavailableForLegalReasons(HTTPException): + """*451* `Unavailable For Legal Reasons` + + This status code indicates that the server is denying access to the + resource as a consequence of a legal demand. + """ + + code = 451 + description = "Unavailable for legal reasons." + + +class InternalServerError(HTTPException): + """*500* `Internal Server Error` + + Raise if an internal server error occurred. This is a good fallback if an + unknown error occurred in the dispatcher. + + .. versionchanged:: 1.0.0 + Added the :attr:`original_exception` attribute. + """ + + code = 500 + description = ( + "The server encountered an internal error and was unable to" + " complete your request. Either the server is overloaded or" + " there is an error in the application." + ) + + def __init__( + self, + description: t.Optional[str] = None, + response: t.Optional["Response"] = None, + original_exception: t.Optional[BaseException] = None, + ) -> None: + #: The original exception that caused this 500 error. Can be + #: used by frameworks to provide context when handling + #: unexpected errors. + self.original_exception = original_exception + super().__init__(description=description, response=response) + + +class NotImplemented(HTTPException): + """*501* `Not Implemented` + + Raise if the application does not support the action requested by the + browser. + """ + + code = 501 + description = "The server does not support the action requested by the browser." + + +class BadGateway(HTTPException): + """*502* `Bad Gateway` + + If you do proxying in your application you should return this status code + if you received an invalid response from the upstream server it accessed + in attempting to fulfill the request. + """ + + code = 502 + description = ( + "The proxy server received an invalid response from an upstream server." + ) + + +class ServiceUnavailable(_RetryAfter): + """*503* `Service Unavailable` + + Status code you should return if a service is temporarily + unavailable. + + :param retry_after: If given, set the ``Retry-After`` header to this + value. May be an :class:`int` number of seconds or a + :class:`~datetime.datetime`. + + .. versionchanged:: 1.0 + Added ``retry_after`` parameter. + """ + + code = 503 + description = ( + "The server is temporarily unable to service your request due" + " to maintenance downtime or capacity problems. Please try" + " again later." + ) + + +class GatewayTimeout(HTTPException): + """*504* `Gateway Timeout` + + Status code you should return if a connection to an upstream server + times out. + """ + + code = 504 + description = "The connection to an upstream server timed out." + + +class HTTPVersionNotSupported(HTTPException): + """*505* `HTTP Version Not Supported` + + The server does not support the HTTP protocol version used in the request. + """ + + code = 505 + description = ( + "The server does not support the HTTP protocol version used in the request." + ) + + +default_exceptions: t.Dict[int, t.Type[HTTPException]] = {} + + +def _find_exceptions() -> None: + for obj in globals().values(): + try: + is_http_exception = issubclass(obj, HTTPException) + except TypeError: + is_http_exception = False + if not is_http_exception or obj.code is None: + continue + old_obj = default_exceptions.get(obj.code, None) + if old_obj is not None and issubclass(obj, old_obj): + continue + default_exceptions[obj.code] = obj + + +_find_exceptions() +del _find_exceptions + + +class Aborter: + """When passed a dict of code -> exception items it can be used as + callable that raises exceptions. If the first argument to the + callable is an integer it will be looked up in the mapping, if it's + a WSGI application it will be raised in a proxy exception. + + The rest of the arguments are forwarded to the exception constructor. + """ + + def __init__( + self, + mapping: t.Optional[t.Dict[int, t.Type[HTTPException]]] = None, + extra: t.Optional[t.Dict[int, t.Type[HTTPException]]] = None, + ) -> None: + if mapping is None: + mapping = default_exceptions + self.mapping = dict(mapping) + if extra is not None: + self.mapping.update(extra) + + def __call__( + self, code: t.Union[int, "Response"], *args: t.Any, **kwargs: t.Any + ) -> "te.NoReturn": + from .sansio.response import Response + + if isinstance(code, Response): + raise HTTPException(response=code) + + if code not in self.mapping: + raise LookupError(f"no exception for {code!r}") + + raise self.mapping[code](*args, **kwargs) + + +def abort( + status: t.Union[int, "Response"], *args: t.Any, **kwargs: t.Any +) -> "te.NoReturn": + """Raises an :py:exc:`HTTPException` for the given status code or WSGI + application. + + If a status code is given, it will be looked up in the list of + exceptions and will raise that exception. If passed a WSGI application, + it will wrap it in a proxy WSGI exception and raise that:: + + abort(404) # 404 Not Found + abort(Response('Hello World')) + + """ + _aborter(status, *args, **kwargs) + + +_aborter: Aborter = Aborter() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/filesystem.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/filesystem.py new file mode 100644 index 00000000..36a3d12e --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/filesystem.py @@ -0,0 +1,55 @@ +import codecs +import sys +import typing as t +import warnings + +# We do not trust traditional unixes. +has_likely_buggy_unicode_filesystem = ( + sys.platform.startswith("linux") or "bsd" in sys.platform +) + + +def _is_ascii_encoding(encoding: t.Optional[str]) -> bool: + """Given an encoding this figures out if the encoding is actually ASCII (which + is something we don't actually want in most cases). This is necessary + because ASCII comes under many names such as ANSI_X3.4-1968. + """ + if encoding is None: + return False + try: + return codecs.lookup(encoding).name == "ascii" + except LookupError: + return False + + +class BrokenFilesystemWarning(RuntimeWarning, UnicodeWarning): + """The warning used by Werkzeug to signal a broken filesystem. Will only be + used once per runtime.""" + + +_warned_about_filesystem_encoding = False + + +def get_filesystem_encoding() -> str: + """Returns the filesystem encoding that should be used. Note that this is + different from the Python understanding of the filesystem encoding which + might be deeply flawed. Do not use this value against Python's string APIs + because it might be different. See :ref:`filesystem-encoding` for the exact + behavior. + + The concept of a filesystem encoding in generally is not something you + should rely on. As such if you ever need to use this function except for + writing wrapper code reconsider. + """ + global _warned_about_filesystem_encoding + rv = sys.getfilesystemencoding() + if has_likely_buggy_unicode_filesystem and not rv or _is_ascii_encoding(rv): + if not _warned_about_filesystem_encoding: + warnings.warn( + "Detected a misconfigured UNIX filesystem: Will use" + f" UTF-8 as filesystem encoding instead of {rv!r}", + BrokenFilesystemWarning, + ) + _warned_about_filesystem_encoding = True + return "utf-8" + return rv diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/formparser.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/formparser.py new file mode 100644 index 00000000..6cb758fe --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/formparser.py @@ -0,0 +1,495 @@ +import typing as t +import warnings +from functools import update_wrapper +from io import BytesIO +from itertools import chain +from typing import Union + +from . import exceptions +from ._internal import _to_str +from .datastructures import FileStorage +from .datastructures import Headers +from .datastructures import MultiDict +from .http import parse_options_header +from .sansio.multipart import Data +from .sansio.multipart import Epilogue +from .sansio.multipart import Field +from .sansio.multipart import File +from .sansio.multipart import MultipartDecoder +from .sansio.multipart import NeedData +from .urls import url_decode_stream +from .wsgi import _make_chunk_iter +from .wsgi import get_content_length +from .wsgi import get_input_stream + +# there are some platforms where SpooledTemporaryFile is not available. +# In that case we need to provide a fallback. +try: + from tempfile import SpooledTemporaryFile +except ImportError: + from tempfile import TemporaryFile + + SpooledTemporaryFile = None # type: ignore + +if t.TYPE_CHECKING: + import typing as te + from _typeshed.wsgi import WSGIEnvironment + + t_parse_result = t.Tuple[t.IO[bytes], MultiDict, MultiDict] + + class TStreamFactory(te.Protocol): + def __call__( + self, + total_content_length: t.Optional[int], + content_type: t.Optional[str], + filename: t.Optional[str], + content_length: t.Optional[int] = None, + ) -> t.IO[bytes]: + ... + + +F = t.TypeVar("F", bound=t.Callable[..., t.Any]) + + +def _exhaust(stream: t.IO[bytes]) -> None: + bts = stream.read(64 * 1024) + while bts: + bts = stream.read(64 * 1024) + + +def default_stream_factory( + total_content_length: t.Optional[int], + content_type: t.Optional[str], + filename: t.Optional[str], + content_length: t.Optional[int] = None, +) -> t.IO[bytes]: + max_size = 1024 * 500 + + if SpooledTemporaryFile is not None: + return t.cast(t.IO[bytes], SpooledTemporaryFile(max_size=max_size, mode="rb+")) + elif total_content_length is None or total_content_length > max_size: + return t.cast(t.IO[bytes], TemporaryFile("rb+")) + + return BytesIO() + + +def parse_form_data( + environ: "WSGIEnvironment", + stream_factory: t.Optional["TStreamFactory"] = None, + charset: str = "utf-8", + errors: str = "replace", + max_form_memory_size: t.Optional[int] = None, + max_content_length: t.Optional[int] = None, + cls: t.Optional[t.Type[MultiDict]] = None, + silent: bool = True, +) -> "t_parse_result": + """Parse the form data in the environ and return it as tuple in the form + ``(stream, form, files)``. You should only call this method if the + transport method is `POST`, `PUT`, or `PATCH`. + + If the mimetype of the data transmitted is `multipart/form-data` the + files multidict will be filled with `FileStorage` objects. If the + mimetype is unknown the input stream is wrapped and returned as first + argument, else the stream is empty. + + This is a shortcut for the common usage of :class:`FormDataParser`. + + Have a look at :doc:`/request_data` for more details. + + .. versionadded:: 0.5 + The `max_form_memory_size`, `max_content_length` and + `cls` parameters were added. + + .. versionadded:: 0.5.1 + The optional `silent` flag was added. + + :param environ: the WSGI environment to be used for parsing. + :param stream_factory: An optional callable that returns a new read and + writeable file descriptor. This callable works + the same as :meth:`Response._get_file_stream`. + :param charset: The character set for URL and url encoded form data. + :param errors: The encoding error behavior. + :param max_form_memory_size: the maximum number of bytes to be accepted for + in-memory stored form data. If the data + exceeds the value specified an + :exc:`~exceptions.RequestEntityTooLarge` + exception is raised. + :param max_content_length: If this is provided and the transmitted data + is longer than this value an + :exc:`~exceptions.RequestEntityTooLarge` + exception is raised. + :param cls: an optional dict class to use. If this is not specified + or `None` the default :class:`MultiDict` is used. + :param silent: If set to False parsing errors will not be caught. + :return: A tuple in the form ``(stream, form, files)``. + """ + return FormDataParser( + stream_factory, + charset, + errors, + max_form_memory_size, + max_content_length, + cls, + silent, + ).parse_from_environ(environ) + + +def exhaust_stream(f: F) -> F: + """Helper decorator for methods that exhausts the stream on return.""" + + def wrapper(self, stream, *args, **kwargs): # type: ignore + try: + return f(self, stream, *args, **kwargs) + finally: + exhaust = getattr(stream, "exhaust", None) + + if exhaust is not None: + exhaust() + else: + while True: + chunk = stream.read(1024 * 64) + + if not chunk: + break + + return update_wrapper(t.cast(F, wrapper), f) + + +class FormDataParser: + """This class implements parsing of form data for Werkzeug. By itself + it can parse multipart and url encoded form data. It can be subclassed + and extended but for most mimetypes it is a better idea to use the + untouched stream and expose it as separate attributes on a request + object. + + .. versionadded:: 0.8 + + :param stream_factory: An optional callable that returns a new read and + writeable file descriptor. This callable works + the same as :meth:`Response._get_file_stream`. + :param charset: The character set for URL and url encoded form data. + :param errors: The encoding error behavior. + :param max_form_memory_size: the maximum number of bytes to be accepted for + in-memory stored form data. If the data + exceeds the value specified an + :exc:`~exceptions.RequestEntityTooLarge` + exception is raised. + :param max_content_length: If this is provided and the transmitted data + is longer than this value an + :exc:`~exceptions.RequestEntityTooLarge` + exception is raised. + :param cls: an optional dict class to use. If this is not specified + or `None` the default :class:`MultiDict` is used. + :param silent: If set to False parsing errors will not be caught. + """ + + def __init__( + self, + stream_factory: t.Optional["TStreamFactory"] = None, + charset: str = "utf-8", + errors: str = "replace", + max_form_memory_size: t.Optional[int] = None, + max_content_length: t.Optional[int] = None, + cls: t.Optional[t.Type[MultiDict]] = None, + silent: bool = True, + ) -> None: + if stream_factory is None: + stream_factory = default_stream_factory + + self.stream_factory = stream_factory + self.charset = charset + self.errors = errors + self.max_form_memory_size = max_form_memory_size + self.max_content_length = max_content_length + + if cls is None: + cls = MultiDict + + self.cls = cls + self.silent = silent + + def get_parse_func( + self, mimetype: str, options: t.Dict[str, str] + ) -> t.Optional[ + t.Callable[ + ["FormDataParser", t.IO[bytes], str, t.Optional[int], t.Dict[str, str]], + "t_parse_result", + ] + ]: + return self.parse_functions.get(mimetype) + + def parse_from_environ(self, environ: "WSGIEnvironment") -> "t_parse_result": + """Parses the information from the environment as form data. + + :param environ: the WSGI environment to be used for parsing. + :return: A tuple in the form ``(stream, form, files)``. + """ + content_type = environ.get("CONTENT_TYPE", "") + content_length = get_content_length(environ) + mimetype, options = parse_options_header(content_type) + return self.parse(get_input_stream(environ), mimetype, content_length, options) + + def parse( + self, + stream: t.IO[bytes], + mimetype: str, + content_length: t.Optional[int], + options: t.Optional[t.Dict[str, str]] = None, + ) -> "t_parse_result": + """Parses the information from the given stream, mimetype, + content length and mimetype parameters. + + :param stream: an input stream + :param mimetype: the mimetype of the data + :param content_length: the content length of the incoming data + :param options: optional mimetype parameters (used for + the multipart boundary for instance) + :return: A tuple in the form ``(stream, form, files)``. + """ + if ( + self.max_content_length is not None + and content_length is not None + and content_length > self.max_content_length + ): + # if the input stream is not exhausted, firefox reports Connection Reset + _exhaust(stream) + raise exceptions.RequestEntityTooLarge() + + if options is None: + options = {} + + parse_func = self.get_parse_func(mimetype, options) + + if parse_func is not None: + try: + return parse_func(self, stream, mimetype, content_length, options) + except ValueError: + if not self.silent: + raise + + return stream, self.cls(), self.cls() + + @exhaust_stream + def _parse_multipart( + self, + stream: t.IO[bytes], + mimetype: str, + content_length: t.Optional[int], + options: t.Dict[str, str], + ) -> "t_parse_result": + parser = MultiPartParser( + self.stream_factory, + self.charset, + self.errors, + max_form_memory_size=self.max_form_memory_size, + cls=self.cls, + ) + boundary = options.get("boundary", "").encode("ascii") + + if not boundary: + raise ValueError("Missing boundary") + + form, files = parser.parse(stream, boundary, content_length) + return stream, form, files + + @exhaust_stream + def _parse_urlencoded( + self, + stream: t.IO[bytes], + mimetype: str, + content_length: t.Optional[int], + options: t.Dict[str, str], + ) -> "t_parse_result": + if ( + self.max_form_memory_size is not None + and content_length is not None + and content_length > self.max_form_memory_size + ): + # if the input stream is not exhausted, firefox reports Connection Reset + _exhaust(stream) + raise exceptions.RequestEntityTooLarge() + + form = url_decode_stream(stream, self.charset, errors=self.errors, cls=self.cls) + return stream, form, self.cls() + + #: mapping of mimetypes to parsing functions + parse_functions: t.Dict[ + str, + t.Callable[ + ["FormDataParser", t.IO[bytes], str, t.Optional[int], t.Dict[str, str]], + "t_parse_result", + ], + ] = { + "multipart/form-data": _parse_multipart, + "application/x-www-form-urlencoded": _parse_urlencoded, + "application/x-url-encoded": _parse_urlencoded, + } + + +def _line_parse(line: str) -> t.Tuple[str, bool]: + """Removes line ending characters and returns a tuple (`stripped_line`, + `is_terminated`). + """ + if line[-2:] == "\r\n": + return line[:-2], True + + elif line[-1:] in {"\r", "\n"}: + return line[:-1], True + + return line, False + + +def parse_multipart_headers(iterable: t.Iterable[bytes]) -> Headers: + """Parses multipart headers from an iterable that yields lines (including + the trailing newline symbol). The iterable has to be newline terminated. + The iterable will stop at the line where the headers ended so it can be + further consumed. + :param iterable: iterable of strings that are newline terminated + """ + warnings.warn( + "'parse_multipart_headers' is deprecated and will be removed in" + " Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + result: t.List[t.Tuple[str, str]] = [] + + for b_line in iterable: + line = _to_str(b_line) + line, line_terminated = _line_parse(line) + + if not line_terminated: + raise ValueError("unexpected end of line in multipart header") + + if not line: + break + elif line[0] in " \t" and result: + key, value = result[-1] + result[-1] = (key, f"{value}\n {line[1:]}") + else: + parts = line.split(":", 1) + + if len(parts) == 2: + result.append((parts[0].strip(), parts[1].strip())) + + # we link the list to the headers, no need to create a copy, the + # list was not shared anyways. + return Headers(result) + + +class MultiPartParser: + def __init__( + self, + stream_factory: t.Optional["TStreamFactory"] = None, + charset: str = "utf-8", + errors: str = "replace", + max_form_memory_size: t.Optional[int] = None, + cls: t.Optional[t.Type[MultiDict]] = None, + buffer_size: int = 64 * 1024, + ) -> None: + self.charset = charset + self.errors = errors + self.max_form_memory_size = max_form_memory_size + + if stream_factory is None: + stream_factory = default_stream_factory + + self.stream_factory = stream_factory + + if cls is None: + cls = MultiDict + + self.cls = cls + + self.buffer_size = buffer_size + + def fail(self, message: str) -> "te.NoReturn": + raise ValueError(message) + + def get_part_charset(self, headers: Headers) -> str: + # Figure out input charset for current part + content_type = headers.get("content-type") + + if content_type: + mimetype, ct_params = parse_options_header(content_type) + return ct_params.get("charset", self.charset) + + return self.charset + + def start_file_streaming( + self, event: File, total_content_length: t.Optional[int] + ) -> t.IO[bytes]: + content_type = event.headers.get("content-type") + + try: + content_length = int(event.headers["content-length"]) + except (KeyError, ValueError): + content_length = 0 + + container = self.stream_factory( + total_content_length=total_content_length, + filename=event.filename, + content_type=content_type, + content_length=content_length, + ) + return container + + def parse( + self, stream: t.IO[bytes], boundary: bytes, content_length: t.Optional[int] + ) -> t.Tuple[MultiDict, MultiDict]: + container: t.Union[t.IO[bytes], t.List[bytes]] + _write: t.Callable[[bytes], t.Any] + + iterator = chain( + _make_chunk_iter( + stream, + limit=content_length, + buffer_size=self.buffer_size, + ), + [None], + ) + + parser = MultipartDecoder(boundary, self.max_form_memory_size) + + fields = [] + files = [] + + current_part: Union[Field, File] + for data in iterator: + parser.receive_data(data) + event = parser.next_event() + while not isinstance(event, (Epilogue, NeedData)): + if isinstance(event, Field): + current_part = event + container = [] + _write = container.append + elif isinstance(event, File): + current_part = event + container = self.start_file_streaming(event, content_length) + _write = container.write + elif isinstance(event, Data): + _write(event.data) + if not event.more_data: + if isinstance(current_part, Field): + value = b"".join(container).decode( + self.get_part_charset(current_part.headers), self.errors + ) + fields.append((current_part.name, value)) + else: + container = t.cast(t.IO[bytes], container) + container.seek(0) + files.append( + ( + current_part.name, + FileStorage( + container, + current_part.filename, + current_part.name, + headers=current_part.headers, + ), + ) + ) + + event = parser.next_event() + + return self.cls(fields), self.cls(files) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/http.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/http.py new file mode 100644 index 00000000..ca48fe21 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/http.py @@ -0,0 +1,1388 @@ +import base64 +import email.utils +import re +import typing +import typing as t +import warnings +from datetime import date +from datetime import datetime +from datetime import time +from datetime import timedelta +from datetime import timezone +from enum import Enum +from hashlib import sha1 +from time import mktime +from time import struct_time +from urllib.parse import unquote_to_bytes as _unquote +from urllib.request import parse_http_list as _parse_list_header + +from ._internal import _cookie_parse_impl +from ._internal import _cookie_quote +from ._internal import _make_cookie_domain +from ._internal import _to_bytes +from ._internal import _to_str +from ._internal import _wsgi_decoding_dance +from werkzeug._internal import _dt_as_utc + +if t.TYPE_CHECKING: + import typing_extensions as te + from _typeshed.wsgi import WSGIEnvironment + +# for explanation of "media-range", etc. see Sections 5.3.{1,2} of RFC 7231 +_accept_re = re.compile( + r""" + ( # media-range capturing-parenthesis + [^\s;,]+ # type/subtype + (?:[ \t]*;[ \t]* # ";" + (?: # parameter non-capturing-parenthesis + [^\s;,q][^\s;,]* # token that doesn't start with "q" + | # or + q[^\s;,=][^\s;,]* # token that is more than just "q" + ) + )* # zero or more parameters + ) # end of media-range + (?:[ \t]*;[ \t]*q= # weight is a "q" parameter + (\d*(?:\.\d+)?) # qvalue capturing-parentheses + [^,]* # "extension" accept params: who cares? + )? # accept params are optional + """, + re.VERBOSE, +) +_token_chars = frozenset( + "!#$%&'*+-.0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ^_`abcdefghijklmnopqrstuvwxyz|~" +) +_etag_re = re.compile(r'([Ww]/)?(?:"(.*?)"|(.*?))(?:\s*,\s*|$)') +_option_header_piece_re = re.compile( + r""" + ;\s*,?\s* # newlines were replaced with commas + (?P + "[^"\\]*(?:\\.[^"\\]*)*" # quoted string + | + [^\s;,=*]+ # token + ) + (?:\*(?P\d+))? # *1, optional continuation index + \s* + (?: # optionally followed by =value + (?: # equals sign, possibly with encoding + \*\s*=\s* # * indicates extended notation + (?: # optional encoding + (?P[^\s]+?) + '(?P[^\s]*?)' + )? + | + =\s* # basic notation + ) + (?P + "[^"\\]*(?:\\.[^"\\]*)*" # quoted string + | + [^;,]+ # token + )? + )? + \s* + """, + flags=re.VERBOSE, +) +_option_header_start_mime_type = re.compile(r",\s*([^;,\s]+)([;,]\s*.+)?") +_entity_headers = frozenset( + [ + "allow", + "content-encoding", + "content-language", + "content-length", + "content-location", + "content-md5", + "content-range", + "content-type", + "expires", + "last-modified", + ] +) +_hop_by_hop_headers = frozenset( + [ + "connection", + "keep-alive", + "proxy-authenticate", + "proxy-authorization", + "te", + "trailer", + "transfer-encoding", + "upgrade", + ] +) +HTTP_STATUS_CODES = { + 100: "Continue", + 101: "Switching Protocols", + 102: "Processing", + 103: "Early Hints", # see RFC 8297 + 200: "OK", + 201: "Created", + 202: "Accepted", + 203: "Non Authoritative Information", + 204: "No Content", + 205: "Reset Content", + 206: "Partial Content", + 207: "Multi Status", + 208: "Already Reported", # see RFC 5842 + 226: "IM Used", # see RFC 3229 + 300: "Multiple Choices", + 301: "Moved Permanently", + 302: "Found", + 303: "See Other", + 304: "Not Modified", + 305: "Use Proxy", + 306: "Switch Proxy", # unused + 307: "Temporary Redirect", + 308: "Permanent Redirect", + 400: "Bad Request", + 401: "Unauthorized", + 402: "Payment Required", # unused + 403: "Forbidden", + 404: "Not Found", + 405: "Method Not Allowed", + 406: "Not Acceptable", + 407: "Proxy Authentication Required", + 408: "Request Timeout", + 409: "Conflict", + 410: "Gone", + 411: "Length Required", + 412: "Precondition Failed", + 413: "Request Entity Too Large", + 414: "Request URI Too Long", + 415: "Unsupported Media Type", + 416: "Requested Range Not Satisfiable", + 417: "Expectation Failed", + 418: "I'm a teapot", # see RFC 2324 + 421: "Misdirected Request", # see RFC 7540 + 422: "Unprocessable Entity", + 423: "Locked", + 424: "Failed Dependency", + 425: "Too Early", # see RFC 8470 + 426: "Upgrade Required", + 428: "Precondition Required", # see RFC 6585 + 429: "Too Many Requests", + 431: "Request Header Fields Too Large", + 449: "Retry With", # proprietary MS extension + 451: "Unavailable For Legal Reasons", + 500: "Internal Server Error", + 501: "Not Implemented", + 502: "Bad Gateway", + 503: "Service Unavailable", + 504: "Gateway Timeout", + 505: "HTTP Version Not Supported", + 506: "Variant Also Negotiates", # see RFC 2295 + 507: "Insufficient Storage", + 508: "Loop Detected", # see RFC 5842 + 510: "Not Extended", + 511: "Network Authentication Failed", +} + + +class COEP(Enum): + """Cross Origin Embedder Policies""" + + UNSAFE_NONE = "unsafe-none" + REQUIRE_CORP = "require-corp" + + +class COOP(Enum): + """Cross Origin Opener Policies""" + + UNSAFE_NONE = "unsafe-none" + SAME_ORIGIN_ALLOW_POPUPS = "same-origin-allow-popups" + SAME_ORIGIN = "same-origin" + + +def quote_header_value( + value: t.Union[str, int], extra_chars: str = "", allow_token: bool = True +) -> str: + """Quote a header value if necessary. + + .. versionadded:: 0.5 + + :param value: the value to quote. + :param extra_chars: a list of extra characters to skip quoting. + :param allow_token: if this is enabled token values are returned + unchanged. + """ + if isinstance(value, bytes): + value = value.decode("latin1") + value = str(value) + if allow_token: + token_chars = _token_chars | set(extra_chars) + if set(value).issubset(token_chars): + return value + value = value.replace("\\", "\\\\").replace('"', '\\"') + return f'"{value}"' + + +def unquote_header_value(value: str, is_filename: bool = False) -> str: + 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. + + .. versionadded:: 0.5 + + :param value: the header value to unquote. + :param is_filename: The value represents a filename or path. + """ + 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 dump_options_header( + header: t.Optional[str], options: t.Mapping[str, t.Optional[t.Union[str, int]]] +) -> str: + """The reverse function to :func:`parse_options_header`. + + :param header: the header to dump + :param options: a dict of options to append. + """ + segments = [] + if header is not None: + segments.append(header) + for key, value in options.items(): + if value is None: + segments.append(key) + else: + segments.append(f"{key}={quote_header_value(value)}") + return "; ".join(segments) + + +def dump_header( + iterable: t.Union[t.Dict[str, t.Union[str, int]], t.Iterable[str]], + allow_token: bool = True, +) -> str: + """Dump an HTTP header again. This is the reversal of + :func:`parse_list_header`, :func:`parse_set_header` and + :func:`parse_dict_header`. This also quotes strings that include an + equals sign unless you pass it as dict of key, value pairs. + + >>> dump_header({'foo': 'bar baz'}) + 'foo="bar baz"' + >>> dump_header(('foo', 'bar baz')) + 'foo, "bar baz"' + + :param iterable: the iterable or dict of values to quote. + :param allow_token: if set to `False` tokens as values are disallowed. + See :func:`quote_header_value` for more details. + """ + if isinstance(iterable, dict): + items = [] + for key, value in iterable.items(): + if value is None: + items.append(key) + else: + items.append( + f"{key}={quote_header_value(value, allow_token=allow_token)}" + ) + else: + items = [quote_header_value(x, allow_token=allow_token) for x in iterable] + return ", ".join(items) + + +def dump_csp_header(header: "ds.ContentSecurityPolicy") -> str: + """Dump a Content Security Policy header. + + These are structured into policies such as "default-src 'self'; + script-src 'self'". + + .. versionadded:: 1.0.0 + Support for Content Security Policy headers was added. + + """ + return "; ".join(f"{key} {value}" for key, value in header.items()) + + +def parse_list_header(value: str) -> t.List[str]: + """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` + """ + 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 + + +def parse_dict_header(value: str, cls: t.Type[dict] = dict) -> t.Dict[str, str]: + """Parse lists of key, value pairs as described by RFC 2068 Section 2 and + convert them into a python dict (or any other mapping object created from + the type with a dict like interface provided by the `cls` argument): + + >>> 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. + + .. versionchanged:: 0.9 + Added support for `cls` argument. + + :param value: a string with a dict header. + :param cls: callable to use for storage of parsed results. + :return: an instance of `cls` + """ + result = cls() + if isinstance(value, bytes): + value = value.decode("latin1") + 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 + + +@typing.overload +def parse_options_header( + value: t.Optional[str], multiple: "te.Literal[False]" = False +) -> t.Tuple[str, t.Dict[str, str]]: + ... + + +@typing.overload +def parse_options_header( + value: t.Optional[str], multiple: "te.Literal[True]" +) -> t.Tuple[t.Any, ...]: + ... + + +def parse_options_header( + value: t.Optional[str], multiple: bool = False +) -> t.Union[t.Tuple[str, t.Dict[str, str]], t.Tuple[t.Any, ...]]: + """Parse a ``Content-Type`` like header into a tuple with the content + type and the options: + + >>> parse_options_header('text/html; charset=utf8') + ('text/html', {'charset': 'utf8'}) + + This should not be used to parse ``Cache-Control`` like headers that use + a slightly different format. For these headers use the + :func:`parse_dict_header` function. + + .. versionchanged:: 0.15 + :rfc:`2231` parameter continuations are handled. + + .. versionadded:: 0.5 + + :param value: the header to parse. + :param multiple: Whether try to parse and return multiple MIME types + :return: (mimetype, options) or (mimetype, options, mimetype, options, …) + if multiple=True + """ + if not value: + return "", {} + + result: t.List[t.Any] = [] + + value = "," + value.replace("\n", ",") + while value: + match = _option_header_start_mime_type.match(value) + if not match: + break + result.append(match.group(1)) # mimetype + options: t.Dict[str, str] = {} + # Parse options + rest = match.group(2) + encoding: t.Optional[str] + continued_encoding: t.Optional[str] = None + while rest: + optmatch = _option_header_piece_re.match(rest) + if not optmatch: + break + option, count, encoding, language, option_value = optmatch.groups() + # Continuations don't have to supply the encoding after the + # first line. If we're in a continuation, track the current + # encoding to use for subsequent lines. Reset it when the + # continuation ends. + if not count: + continued_encoding = None + else: + if not encoding: + encoding = continued_encoding + continued_encoding = encoding + option = unquote_header_value(option) + if option_value is not None: + option_value = unquote_header_value(option_value, option == "filename") + if encoding is not None: + option_value = _unquote(option_value).decode(encoding) + if count: + # Continuations append to the existing value. For + # simplicity, this ignores the possibility of + # out-of-order indices, which shouldn't happen anyway. + options[option] = options.get(option, "") + option_value + else: + options[option] = option_value + rest = rest[optmatch.end() :] + result.append(options) + if multiple is False: + return tuple(result) + value = rest + + return tuple(result) if result else ("", {}) + + +_TAnyAccept = t.TypeVar("_TAnyAccept", bound="ds.Accept") + + +@typing.overload +def parse_accept_header(value: t.Optional[str]) -> "ds.Accept": + ... + + +@typing.overload +def parse_accept_header( + value: t.Optional[str], cls: t.Type[_TAnyAccept] +) -> _TAnyAccept: + ... + + +def parse_accept_header( + value: t.Optional[str], cls: t.Optional[t.Type[_TAnyAccept]] = None +) -> _TAnyAccept: + """Parses an HTTP Accept-* header. This does not implement a complete + valid algorithm but one that supports at least value and quality + extraction. + + Returns a new :class:`Accept` object (basically a list of ``(value, quality)`` + tuples sorted by the quality with some additional accessor methods). + + The second parameter can be a subclass of :class:`Accept` that is created + with the parsed values and returned. + + :param value: the accept header string to be parsed. + :param cls: the wrapper class for the return value (can be + :class:`Accept` or a subclass thereof) + :return: an instance of `cls`. + """ + if cls is None: + cls = t.cast(t.Type[_TAnyAccept], ds.Accept) + + if not value: + return cls(None) + + result = [] + for match in _accept_re.finditer(value): + quality_match = match.group(2) + if not quality_match: + quality: float = 1 + else: + quality = max(min(float(quality_match), 1), 0) + result.append((match.group(1), quality)) + return cls(result) + + +_TAnyCC = t.TypeVar("_TAnyCC", bound="ds._CacheControl") +_t_cc_update = t.Optional[t.Callable[[_TAnyCC], None]] + + +@typing.overload +def parse_cache_control_header( + value: t.Optional[str], on_update: _t_cc_update, cls: None = None +) -> "ds.RequestCacheControl": + ... + + +@typing.overload +def parse_cache_control_header( + value: t.Optional[str], on_update: _t_cc_update, cls: t.Type[_TAnyCC] +) -> _TAnyCC: + ... + + +def parse_cache_control_header( + value: t.Optional[str], + on_update: _t_cc_update = None, + cls: t.Optional[t.Type[_TAnyCC]] = None, +) -> _TAnyCC: + """Parse a cache control header. The RFC differs between response and + request cache control, this method does not. It's your responsibility + to not use the wrong control statements. + + .. versionadded:: 0.5 + The `cls` was added. If not specified an immutable + :class:`~werkzeug.datastructures.RequestCacheControl` is returned. + + :param value: a cache control header to be parsed. + :param on_update: an optional callable that is called every time a value + on the :class:`~werkzeug.datastructures.CacheControl` + object is changed. + :param cls: the class for the returned object. By default + :class:`~werkzeug.datastructures.RequestCacheControl` is used. + :return: a `cls` object. + """ + if cls is None: + cls = t.cast(t.Type[_TAnyCC], ds.RequestCacheControl) + + if not value: + return cls((), on_update) + + return cls(parse_dict_header(value), on_update) + + +_TAnyCSP = t.TypeVar("_TAnyCSP", bound="ds.ContentSecurityPolicy") +_t_csp_update = t.Optional[t.Callable[[_TAnyCSP], None]] + + +@typing.overload +def parse_csp_header( + value: t.Optional[str], on_update: _t_csp_update, cls: None = None +) -> "ds.ContentSecurityPolicy": + ... + + +@typing.overload +def parse_csp_header( + value: t.Optional[str], on_update: _t_csp_update, cls: t.Type[_TAnyCSP] +) -> _TAnyCSP: + ... + + +def parse_csp_header( + value: t.Optional[str], + on_update: _t_csp_update = None, + cls: t.Optional[t.Type[_TAnyCSP]] = None, +) -> _TAnyCSP: + """Parse a Content Security Policy header. + + .. versionadded:: 1.0.0 + Support for Content Security Policy headers was added. + + :param value: a csp header to be parsed. + :param on_update: an optional callable that is called every time a value + on the object is changed. + :param cls: the class for the returned object. By default + :class:`~werkzeug.datastructures.ContentSecurityPolicy` is used. + :return: a `cls` object. + """ + if cls is None: + cls = t.cast(t.Type[_TAnyCSP], ds.ContentSecurityPolicy) + + if value is None: + return cls((), on_update) + + items = [] + + for policy in value.split(";"): + policy = policy.strip() + + # Ignore badly formatted policies (no space) + if " " in policy: + directive, value = policy.strip().split(" ", 1) + items.append((directive.strip(), value.strip())) + + return cls(items, on_update) + + +def parse_set_header( + value: t.Optional[str], + on_update: t.Optional[t.Callable[["ds.HeaderSet"], None]] = None, +) -> "ds.HeaderSet": + """Parse a set-like header and return a + :class:`~werkzeug.datastructures.HeaderSet` object: + + >>> hs = parse_set_header('token, "quoted value"') + + The return value is an object that treats the items case-insensitively + and keeps the order of the items: + + >>> 'TOKEN' in hs + True + >>> hs.index('quoted value') + 1 + >>> hs + HeaderSet(['token', 'quoted value']) + + To create a header from the :class:`HeaderSet` again, use the + :func:`dump_header` function. + + :param value: a set header to be parsed. + :param on_update: an optional callable that is called every time a + value on the :class:`~werkzeug.datastructures.HeaderSet` + object is changed. + :return: a :class:`~werkzeug.datastructures.HeaderSet` + """ + if not value: + return ds.HeaderSet(None, on_update) + return ds.HeaderSet(parse_list_header(value), on_update) + + +def parse_authorization_header( + value: t.Optional[str], +) -> t.Optional["ds.Authorization"]: + """Parse an HTTP basic/digest authorization header transmitted by the web + browser. The return value is either `None` if the header was invalid or + not given, otherwise an :class:`~werkzeug.datastructures.Authorization` + object. + + :param value: the authorization header to parse. + :return: a :class:`~werkzeug.datastructures.Authorization` object or `None`. + """ + if not value: + return None + value = _wsgi_decoding_dance(value) + try: + auth_type, auth_info = value.split(None, 1) + auth_type = auth_type.lower() + except ValueError: + return None + if auth_type == "basic": + try: + username, password = base64.b64decode(auth_info).split(b":", 1) + except Exception: + return None + try: + return ds.Authorization( + "basic", + { + "username": _to_str(username, "utf-8"), + "password": _to_str(password, "utf-8"), + }, + ) + except UnicodeDecodeError: + return None + elif auth_type == "digest": + auth_map = parse_dict_header(auth_info) + for key in "username", "realm", "nonce", "uri", "response": + if key not in auth_map: + return None + if "qop" in auth_map: + if not auth_map.get("nc") or not auth_map.get("cnonce"): + return None + return ds.Authorization("digest", auth_map) + return None + + +def parse_www_authenticate_header( + value: t.Optional[str], + on_update: t.Optional[t.Callable[["ds.WWWAuthenticate"], None]] = None, +) -> "ds.WWWAuthenticate": + """Parse an HTTP WWW-Authenticate header into a + :class:`~werkzeug.datastructures.WWWAuthenticate` object. + + :param value: a WWW-Authenticate header to parse. + :param on_update: an optional callable that is called every time a value + on the :class:`~werkzeug.datastructures.WWWAuthenticate` + object is changed. + :return: a :class:`~werkzeug.datastructures.WWWAuthenticate` object. + """ + if not value: + return ds.WWWAuthenticate(on_update=on_update) + try: + auth_type, auth_info = value.split(None, 1) + auth_type = auth_type.lower() + except (ValueError, AttributeError): + return ds.WWWAuthenticate(value.strip().lower(), on_update=on_update) + return ds.WWWAuthenticate(auth_type, parse_dict_header(auth_info), on_update) + + +def parse_if_range_header(value: t.Optional[str]) -> "ds.IfRange": + """Parses an if-range header which can be an etag or a date. Returns + a :class:`~werkzeug.datastructures.IfRange` object. + + .. versionchanged:: 2.0 + If the value represents a datetime, it is timezone-aware. + + .. versionadded:: 0.7 + """ + if not value: + return ds.IfRange() + date = parse_date(value) + if date is not None: + return ds.IfRange(date=date) + # drop weakness information + return ds.IfRange(unquote_etag(value)[0]) + + +def parse_range_header( + value: t.Optional[str], make_inclusive: bool = True +) -> t.Optional["ds.Range"]: + """Parses a range header into a :class:`~werkzeug.datastructures.Range` + object. If the header is missing or malformed `None` is returned. + `ranges` is a list of ``(start, stop)`` tuples where the ranges are + non-inclusive. + + .. versionadded:: 0.7 + """ + if not value or "=" not in value: + return None + + ranges = [] + last_end = 0 + units, rng = value.split("=", 1) + units = units.strip().lower() + + for item in rng.split(","): + item = item.strip() + if "-" not in item: + return None + if item.startswith("-"): + if last_end < 0: + return None + try: + begin = int(item) + except ValueError: + return None + end = None + last_end = -1 + elif "-" in item: + begin_str, end_str = item.split("-", 1) + begin_str = begin_str.strip() + end_str = end_str.strip() + if not begin_str.isdigit(): + return None + begin = int(begin_str) + if begin < last_end or last_end < 0: + return None + if end_str: + if not end_str.isdigit(): + return None + end = int(end_str) + 1 + if begin >= end: + return None + else: + end = None + last_end = end if end is not None else -1 + ranges.append((begin, end)) + + return ds.Range(units, ranges) + + +def parse_content_range_header( + value: t.Optional[str], + on_update: t.Optional[t.Callable[["ds.ContentRange"], None]] = None, +) -> t.Optional["ds.ContentRange"]: + """Parses a range header into a + :class:`~werkzeug.datastructures.ContentRange` object or `None` if + parsing is not possible. + + .. versionadded:: 0.7 + + :param value: a content range header to be parsed. + :param on_update: an optional callable that is called every time a value + on the :class:`~werkzeug.datastructures.ContentRange` + object is changed. + """ + if value is None: + return None + try: + units, rangedef = (value or "").strip().split(None, 1) + except ValueError: + return None + + if "/" not in rangedef: + return None + rng, length_str = rangedef.split("/", 1) + if length_str == "*": + length = None + elif length_str.isdigit(): + length = int(length_str) + else: + return None + + if rng == "*": + return ds.ContentRange(units, None, None, length, on_update=on_update) + elif "-" not in rng: + return None + + start_str, stop_str = rng.split("-", 1) + try: + start = int(start_str) + stop = int(stop_str) + 1 + except ValueError: + return None + + if is_byte_range_valid(start, stop, length): + return ds.ContentRange(units, start, stop, length, on_update=on_update) + + return None + + +def quote_etag(etag: str, weak: bool = False) -> str: + """Quote an etag. + + :param etag: the etag to quote. + :param weak: set to `True` to tag it "weak". + """ + if '"' in etag: + raise ValueError("invalid etag") + etag = f'"{etag}"' + if weak: + etag = f"W/{etag}" + return etag + + +def unquote_etag( + etag: t.Optional[str], +) -> t.Union[t.Tuple[str, bool], t.Tuple[None, None]]: + """Unquote a single etag: + + >>> unquote_etag('W/"bar"') + ('bar', True) + >>> unquote_etag('"bar"') + ('bar', False) + + :param etag: the etag identifier to unquote. + :return: a ``(etag, weak)`` tuple. + """ + if not etag: + return None, None + etag = etag.strip() + weak = False + if etag.startswith(("W/", "w/")): + weak = True + etag = etag[2:] + if etag[:1] == etag[-1:] == '"': + etag = etag[1:-1] + return etag, weak + + +def parse_etags(value: t.Optional[str]) -> "ds.ETags": + """Parse an etag header. + + :param value: the tag header to parse + :return: an :class:`~werkzeug.datastructures.ETags` object. + """ + if not value: + return ds.ETags() + strong = [] + weak = [] + end = len(value) + pos = 0 + while pos < end: + match = _etag_re.match(value, pos) + if match is None: + break + is_weak, quoted, raw = match.groups() + if raw == "*": + return ds.ETags(star_tag=True) + elif quoted: + raw = quoted + if is_weak: + weak.append(raw) + else: + strong.append(raw) + pos = match.end() + return ds.ETags(strong, weak) + + +def generate_etag(data: bytes) -> str: + """Generate an etag for some data. + + .. versionchanged:: 2.0 + Use SHA-1. MD5 may not be available in some environments. + """ + return sha1(data).hexdigest() + + +def parse_date(value: t.Optional[str]) -> t.Optional[datetime]: + """Parse an :rfc:`2822` date into a timezone-aware + :class:`datetime.datetime` object, or ``None`` if parsing fails. + + This is a wrapper for :func:`email.utils.parsedate_to_datetime`. It + returns ``None`` if parsing fails instead of raising an exception, + and always returns a timezone-aware datetime object. If the string + doesn't have timezone information, it is assumed to be UTC. + + :param value: A string with a supported date format. + + .. versionchanged:: 2.0 + Return a timezone-aware datetime object. Use + ``email.utils.parsedate_to_datetime``. + """ + if value is None: + return None + + try: + dt = email.utils.parsedate_to_datetime(value) + except (TypeError, ValueError): + return None + + if dt.tzinfo is None: + return dt.replace(tzinfo=timezone.utc) + + return dt + + +def cookie_date( + expires: t.Optional[t.Union[datetime, date, int, float, struct_time]] = None +) -> str: + """Format a datetime object or timestamp into an :rfc:`2822` date + string for ``Set-Cookie expires``. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :func:`http_date` instead. + """ + warnings.warn( + "'cookie_date' is deprecated and will be removed in Werkzeug" + " 2.1. Use 'http_date' instead.", + DeprecationWarning, + stacklevel=2, + ) + return http_date(expires) + + +def http_date( + timestamp: t.Optional[t.Union[datetime, date, int, float, struct_time]] = None +) -> str: + """Format a datetime object or timestamp into an :rfc:`2822` date + string. + + This is a wrapper for :func:`email.utils.format_datetime`. It + assumes naive datetime objects are in UTC instead of raising an + exception. + + :param timestamp: The datetime or timestamp to format. Defaults to + the current time. + + .. versionchanged:: 2.0 + Use ``email.utils.format_datetime``. Accept ``date`` objects. + """ + if isinstance(timestamp, date): + if not isinstance(timestamp, datetime): + # Assume plain date is midnight UTC. + timestamp = datetime.combine(timestamp, time(), tzinfo=timezone.utc) + else: + # Ensure datetime is timezone-aware. + timestamp = _dt_as_utc(timestamp) + + return email.utils.format_datetime(timestamp, usegmt=True) + + if isinstance(timestamp, struct_time): + timestamp = mktime(timestamp) + + return email.utils.formatdate(timestamp, usegmt=True) + + +def parse_age(value: t.Optional[str] = None) -> t.Optional[timedelta]: + """Parses a base-10 integer count of seconds into a timedelta. + + If parsing fails, the return value is `None`. + + :param value: a string consisting of an integer represented in base-10 + :return: a :class:`datetime.timedelta` object or `None`. + """ + if not value: + return None + try: + seconds = int(value) + except ValueError: + return None + if seconds < 0: + return None + try: + return timedelta(seconds=seconds) + except OverflowError: + return None + + +def dump_age(age: t.Optional[t.Union[timedelta, int]] = None) -> t.Optional[str]: + """Formats the duration as a base-10 integer. + + :param age: should be an integer number of seconds, + a :class:`datetime.timedelta` object, or, + if the age is unknown, `None` (default). + """ + if age is None: + return None + if isinstance(age, timedelta): + age = int(age.total_seconds()) + else: + age = int(age) + + if age < 0: + raise ValueError("age cannot be negative") + + return str(age) + + +def is_resource_modified( + environ: "WSGIEnvironment", + etag: t.Optional[str] = None, + data: t.Optional[bytes] = None, + last_modified: t.Optional[t.Union[datetime, str]] = None, + ignore_if_range: bool = True, +) -> bool: + """Convenience method for conditional requests. + + :param environ: the WSGI environment of the request to be checked. + :param etag: the etag for the response for comparison. + :param data: or alternatively the data of the response to automatically + generate an etag using :func:`generate_etag`. + :param last_modified: an optional date of the last modification. + :param ignore_if_range: If `False`, `If-Range` header will be taken into + account. + :return: `True` if the resource was modified, otherwise `False`. + + .. versionchanged:: 2.0 + SHA-1 is used to generate an etag value for the data. MD5 may + not be available in some environments. + + .. versionchanged:: 1.0.0 + The check is run for methods other than ``GET`` and ``HEAD``. + """ + if etag is None and data is not None: + etag = generate_etag(data) + elif data is not None: + raise TypeError("both data and etag given") + + unmodified = False + if isinstance(last_modified, str): + last_modified = parse_date(last_modified) + + # HTTP doesn't use microsecond, remove it to avoid false positive + # comparisons. Mark naive datetimes as UTC. + if last_modified is not None: + last_modified = _dt_as_utc(last_modified.replace(microsecond=0)) + + if_range = None + if not ignore_if_range and "HTTP_RANGE" in environ: + # https://tools.ietf.org/html/rfc7233#section-3.2 + # A server MUST ignore an If-Range header field received in a request + # that does not contain a Range header field. + if_range = parse_if_range_header(environ.get("HTTP_IF_RANGE")) + + if if_range is not None and if_range.date is not None: + modified_since: t.Optional[datetime] = if_range.date + else: + modified_since = parse_date(environ.get("HTTP_IF_MODIFIED_SINCE")) + + if modified_since and last_modified and last_modified <= modified_since: + unmodified = True + + if etag: + etag, _ = unquote_etag(etag) + etag = t.cast(str, etag) + + if if_range is not None and if_range.etag is not None: + unmodified = parse_etags(if_range.etag).contains(etag) + else: + if_none_match = parse_etags(environ.get("HTTP_IF_NONE_MATCH")) + if if_none_match: + # https://tools.ietf.org/html/rfc7232#section-3.2 + # "A recipient MUST use the weak comparison function when comparing + # entity-tags for If-None-Match" + unmodified = if_none_match.contains_weak(etag) + + # https://tools.ietf.org/html/rfc7232#section-3.1 + # "Origin server MUST use the strong comparison function when + # comparing entity-tags for If-Match" + if_match = parse_etags(environ.get("HTTP_IF_MATCH")) + if if_match: + unmodified = not if_match.is_strong(etag) + + return not unmodified + + +def remove_entity_headers( + headers: t.Union["ds.Headers", t.List[t.Tuple[str, str]]], + allowed: t.Iterable[str] = ("expires", "content-location"), +) -> None: + """Remove all entity headers from a list or :class:`Headers` object. This + operation works in-place. `Expires` and `Content-Location` headers are + by default not removed. The reason for this is :rfc:`2616` section + 10.3.5 which specifies some entity headers that should be sent. + + .. versionchanged:: 0.5 + added `allowed` parameter. + + :param headers: a list or :class:`Headers` object. + :param allowed: a list of headers that should still be allowed even though + they are entity headers. + """ + allowed = {x.lower() for x in allowed} + headers[:] = [ + (key, value) + for key, value in headers + if not is_entity_header(key) or key.lower() in allowed + ] + + +def remove_hop_by_hop_headers( + headers: t.Union["ds.Headers", t.List[t.Tuple[str, str]]] +) -> None: + """Remove all HTTP/1.1 "Hop-by-Hop" headers from a list or + :class:`Headers` object. This operation works in-place. + + .. versionadded:: 0.5 + + :param headers: a list or :class:`Headers` object. + """ + headers[:] = [ + (key, value) for key, value in headers if not is_hop_by_hop_header(key) + ] + + +def is_entity_header(header: str) -> bool: + """Check if a header is an entity header. + + .. versionadded:: 0.5 + + :param header: the header to test. + :return: `True` if it's an entity header, `False` otherwise. + """ + return header.lower() in _entity_headers + + +def is_hop_by_hop_header(header: str) -> bool: + """Check if a header is an HTTP/1.1 "Hop-by-Hop" header. + + .. versionadded:: 0.5 + + :param header: the header to test. + :return: `True` if it's an HTTP/1.1 "Hop-by-Hop" header, `False` otherwise. + """ + return header.lower() in _hop_by_hop_headers + + +def parse_cookie( + header: t.Union["WSGIEnvironment", str, bytes, None], + charset: str = "utf-8", + errors: str = "replace", + cls: t.Optional[t.Type["ds.MultiDict"]] = None, +) -> "ds.MultiDict[str, str]": + """Parse a cookie from a string or WSGI environ. + + The same key can be provided multiple times, the values are stored + in-order. The default :class:`MultiDict` will have the first value + first, and all values can be retrieved with + :meth:`MultiDict.getlist`. + + :param header: The cookie header as a string, or a WSGI environ dict + with a ``HTTP_COOKIE`` key. + :param charset: The charset for the cookie values. + :param errors: The error behavior for the charset decoding. + :param cls: A dict-like class to store the parsed cookies in. + Defaults to :class:`MultiDict`. + + .. versionchanged:: 1.0.0 + Returns a :class:`MultiDict` instead of a + ``TypeConversionDict``. + + .. versionchanged:: 0.5 + Returns a :class:`TypeConversionDict` instead of a regular dict. + The ``cls`` parameter was added. + """ + if isinstance(header, dict): + header = header.get("HTTP_COOKIE", "") + elif header is None: + header = "" + + # PEP 3333 sends headers through the environ as latin1 decoded + # strings. Encode strings back to bytes for parsing. + if isinstance(header, str): + header = header.encode("latin1", "replace") + + if cls is None: + cls = ds.MultiDict + + def _parse_pairs() -> t.Iterator[t.Tuple[str, str]]: + for key, val in _cookie_parse_impl(header): # type: ignore + key_str = _to_str(key, charset, errors, allow_none_charset=True) + + if not key_str: + continue + + val_str = _to_str(val, charset, errors, allow_none_charset=True) + yield key_str, val_str + + return cls(_parse_pairs()) + + +def dump_cookie( + key: str, + value: t.Union[bytes, str] = "", + max_age: t.Optional[t.Union[timedelta, int]] = None, + expires: t.Optional[t.Union[str, datetime, int, float]] = None, + path: t.Optional[str] = "/", + domain: t.Optional[str] = None, + secure: bool = False, + httponly: bool = False, + charset: str = "utf-8", + sync_expires: bool = True, + max_size: int = 4093, + samesite: t.Optional[str] = None, +) -> str: + """Create a Set-Cookie header without the ``Set-Cookie`` prefix. + + The return value is usually restricted to ascii as the vast majority + of values are properly escaped, but that is no guarantee. It's + tunneled through latin1 as required by :pep:`3333`. + + The return value is not ASCII safe if the key contains unicode + characters. This is technically against the specification but + happens in the wild. It's strongly recommended to not use + non-ASCII values for the keys. + + :param max_age: should be a number of seconds, or `None` (default) if + the cookie should last only as long as the client's + browser session. Additionally `timedelta` objects + are accepted, too. + :param expires: should be a `datetime` object or unix timestamp. + :param path: limits the cookie to a given path, per default it will + span the whole domain. + :param domain: Use this if you want to set a cross-domain cookie. For + example, ``domain=".example.com"`` will set a cookie + that is readable by the domain ``www.example.com``, + ``foo.example.com`` etc. Otherwise, a cookie will only + be readable by the domain that set it. + :param secure: The cookie will only be available via HTTPS + :param httponly: disallow JavaScript to access the cookie. This is an + extension to the cookie standard and probably not + supported by all browsers. + :param charset: the encoding for string values. + :param sync_expires: automatically set expires if max_age is defined + but expires not. + :param max_size: Warn if the final header value exceeds this size. The + default, 4093, should be safely `supported by most browsers + `_. Set to 0 to disable this check. + :param samesite: Limits the scope of the cookie such that it will + only be attached to requests if those requests are same-site. + + .. _`cookie`: http://browsercookielimits.squawky.net/ + + .. versionchanged:: 1.0.0 + The string ``'None'`` is accepted for ``samesite``. + """ + key = _to_bytes(key, charset) + value = _to_bytes(value, charset) + + if path is not None: + from .urls import iri_to_uri + + path = iri_to_uri(path, charset) + + domain = _make_cookie_domain(domain) + + if isinstance(max_age, timedelta): + max_age = int(max_age.total_seconds()) + + if expires is not None: + if not isinstance(expires, str): + expires = http_date(expires) + elif max_age is not None and sync_expires: + expires = http_date(datetime.now(tz=timezone.utc).timestamp() + max_age) + + if samesite is not None: + samesite = samesite.title() + + if samesite not in {"Strict", "Lax", "None"}: + raise ValueError("SameSite must be 'Strict', 'Lax', or 'None'.") + + buf = [key + b"=" + _cookie_quote(value)] + + # XXX: In theory all of these parameters that are not marked with `None` + # should be quoted. Because stdlib did not quote it before I did not + # want to introduce quoting there now. + for k, v, q in ( + (b"Domain", domain, True), + (b"Expires", expires, False), + (b"Max-Age", max_age, False), + (b"Secure", secure, None), + (b"HttpOnly", httponly, None), + (b"Path", path, False), + (b"SameSite", samesite, False), + ): + if q is None: + if v: + buf.append(k) + continue + + if v is None: + continue + + tmp = bytearray(k) + if not isinstance(v, (bytes, bytearray)): + v = _to_bytes(str(v), charset) + if q: + v = _cookie_quote(v) + tmp += b"=" + v + buf.append(bytes(tmp)) + + # The return value will be an incorrectly encoded latin1 header for + # consistency with the headers object. + rv = b"; ".join(buf) + rv = rv.decode("latin1") + + # Warn if the final value of the cookie is larger than the limit. If the + # cookie is too large, then it may be silently ignored by the browser, + # which can be quite hard to debug. + cookie_size = len(rv) + + if max_size and cookie_size > max_size: + value_size = len(value) + warnings.warn( + f"The {key.decode(charset)!r} cookie is too large: the value was" + f" {value_size} bytes but the" + f" header required {cookie_size - value_size} extra bytes. The final size" + f" was {cookie_size} bytes but the limit is {max_size} bytes. Browsers may" + f" silently ignore cookies larger than this.", + stacklevel=2, + ) + + return rv + + +def is_byte_range_valid( + start: t.Optional[int], stop: t.Optional[int], length: t.Optional[int] +) -> bool: + """Checks if a given byte content range is valid for the given length. + + .. versionadded:: 0.7 + """ + if (start is None) != (stop is None): + return False + elif start is None: + return length is None or length >= 0 + elif length is None: + return 0 <= start < stop # type: ignore + elif start >= stop: # type: ignore + return False + return 0 <= start < length + + +# circular dependencies +from . import datastructures as ds diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/local.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/local.py new file mode 100644 index 00000000..b4dee7b4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/local.py @@ -0,0 +1,677 @@ +import copy +import math +import operator +import sys +import typing as t +import warnings +from functools import partial +from functools import update_wrapper + +from .wsgi import ClosingIterator + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + +F = t.TypeVar("F", bound=t.Callable[..., t.Any]) + +try: + from greenlet import getcurrent as _get_ident +except ImportError: + from threading import get_ident as _get_ident + + +def get_ident() -> int: + warnings.warn( + "'get_ident' is deprecated and will be removed in Werkzeug" + " 2.1. Use 'greenlet.getcurrent' or 'threading.get_ident' for" + " previous behavior.", + DeprecationWarning, + stacklevel=2, + ) + return _get_ident() # type: ignore + + +class _CannotUseContextVar(Exception): + pass + + +try: + from contextvars import ContextVar + + if "gevent" in sys.modules or "eventlet" in sys.modules: + # Both use greenlet, so first check it has patched + # ContextVars, Greenlet <0.4.17 does not. + import greenlet + + greenlet_patched = getattr(greenlet, "GREENLET_USE_CONTEXT_VARS", False) + + if not greenlet_patched: + # If Gevent is used, check it has patched ContextVars, + # <20.5 does not. + try: + from gevent.monkey import is_object_patched + except ImportError: + # Gevent isn't used, but Greenlet is and hasn't patched + raise _CannotUseContextVar() from None + else: + if is_object_patched("threading", "local") and not is_object_patched( + "contextvars", "ContextVar" + ): + raise _CannotUseContextVar() + + def __release_local__(storage: t.Any) -> None: + # Can remove when support for non-stdlib ContextVars is + # removed, see "Fake" version below. + storage.set({}) + + +except (ImportError, _CannotUseContextVar): + + class ContextVar: # type: ignore + """A fake ContextVar based on the previous greenlet/threading + ident function. Used on Python 3.6, eventlet, and old versions + of gevent. + """ + + def __init__(self, _name: str) -> None: + self.storage: t.Dict[int, t.Dict[str, t.Any]] = {} + + def get(self, default: t.Dict[str, t.Any]) -> t.Dict[str, t.Any]: + return self.storage.get(_get_ident(), default) + + def set(self, value: t.Dict[str, t.Any]) -> None: + self.storage[_get_ident()] = value + + def __release_local__(storage: t.Any) -> None: + # Special version to ensure that the storage is cleaned up on + # release. + storage.storage.pop(_get_ident(), None) + + +def release_local(local: t.Union["Local", "LocalStack"]) -> None: + """Releases the contents of the local for the current context. + This makes it possible to use locals without a manager. + + Example:: + + >>> loc = Local() + >>> loc.foo = 42 + >>> release_local(loc) + >>> hasattr(loc, 'foo') + False + + With this function one can release :class:`Local` objects as well + as :class:`LocalStack` objects. However it is not possible to + release data held by proxies that way, one always has to retain + a reference to the underlying local object in order to be able + to release it. + + .. versionadded:: 0.6.1 + """ + local.__release_local__() + + +class Local: + __slots__ = ("_storage",) + + def __init__(self) -> None: + object.__setattr__(self, "_storage", ContextVar("local_storage")) + + @property + def __storage__(self) -> t.Dict[str, t.Any]: + warnings.warn( + "'__storage__' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + return self._storage.get({}) # type: ignore + + @property + def __ident_func__(self) -> t.Callable[[], int]: + warnings.warn( + "'__ident_func__' is deprecated and will be removed in" + " Werkzeug 2.1. It should not be used in Python 3.7+.", + DeprecationWarning, + stacklevel=2, + ) + return _get_ident # type: ignore + + @__ident_func__.setter + def __ident_func__(self, func: t.Callable[[], int]) -> None: + warnings.warn( + "'__ident_func__' is deprecated and will be removed in" + " Werkzeug 2.1. Setting it no longer has any effect.", + DeprecationWarning, + stacklevel=2, + ) + + def __iter__(self) -> t.Iterator[t.Tuple[int, t.Any]]: + return iter(self._storage.get({}).items()) + + def __call__(self, proxy: str) -> "LocalProxy": + """Create a proxy for a name.""" + return LocalProxy(self, proxy) + + def __release_local__(self) -> None: + __release_local__(self._storage) + + def __getattr__(self, name: str) -> t.Any: + values = self._storage.get({}) + try: + return values[name] + except KeyError: + raise AttributeError(name) from None + + def __setattr__(self, name: str, value: t.Any) -> None: + values = self._storage.get({}).copy() + values[name] = value + self._storage.set(values) + + def __delattr__(self, name: str) -> None: + values = self._storage.get({}).copy() + try: + del values[name] + self._storage.set(values) + except KeyError: + raise AttributeError(name) from None + + +class LocalStack: + """This class works similar to a :class:`Local` but keeps a stack + of objects instead. This is best explained with an example:: + + >>> ls = LocalStack() + >>> ls.push(42) + >>> ls.top + 42 + >>> ls.push(23) + >>> ls.top + 23 + >>> ls.pop() + 23 + >>> ls.top + 42 + + They can be force released by using a :class:`LocalManager` or with + the :func:`release_local` function but the correct way is to pop the + item from the stack after using. When the stack is empty it will + no longer be bound to the current context (and as such released). + + By calling the stack without arguments it returns a proxy that resolves to + the topmost item on the stack. + + .. versionadded:: 0.6.1 + """ + + def __init__(self) -> None: + self._local = Local() + + def __release_local__(self) -> None: + self._local.__release_local__() + + @property + def __ident_func__(self) -> t.Callable[[], int]: + return self._local.__ident_func__ + + @__ident_func__.setter + def __ident_func__(self, value: t.Callable[[], int]) -> None: + object.__setattr__(self._local, "__ident_func__", value) + + def __call__(self) -> "LocalProxy": + def _lookup() -> t.Any: + rv = self.top + if rv is None: + raise RuntimeError("object unbound") + return rv + + return LocalProxy(_lookup) + + def push(self, obj: t.Any) -> t.List[t.Any]: + """Pushes a new item to the stack""" + rv = getattr(self._local, "stack", []).copy() + rv.append(obj) + self._local.stack = rv + return rv # type: ignore + + def pop(self) -> t.Any: + """Removes the topmost item from the stack, will return the + old value or `None` if the stack was already empty. + """ + stack = getattr(self._local, "stack", None) + if stack is None: + return None + elif len(stack) == 1: + release_local(self._local) + return stack[-1] + else: + return stack.pop() + + @property + def top(self) -> t.Any: + """The topmost item on the stack. If the stack is empty, + `None` is returned. + """ + try: + return self._local.stack[-1] + except (AttributeError, IndexError): + return None + + +class LocalManager: + """Local objects cannot manage themselves. For that you need a local + manager. You can pass a local manager multiple locals or add them + later by appending them to `manager.locals`. Every time the manager + cleans up, it will clean up all the data left in the locals for this + context. + + .. versionchanged:: 2.0 + ``ident_func`` is deprecated and will be removed in Werkzeug + 2.1. + + .. versionchanged:: 0.6.1 + The :func:`release_local` function can be used instead of a + manager. + + .. versionchanged:: 0.7 + The ``ident_func`` parameter was added. + """ + + def __init__( + self, + locals: t.Optional[t.Iterable[t.Union[Local, LocalStack]]] = None, + ident_func: None = None, + ) -> None: + if locals is None: + self.locals = [] + elif isinstance(locals, Local): + self.locals = [locals] + else: + self.locals = list(locals) + + if ident_func is not None: + warnings.warn( + "'ident_func' is deprecated and will be removed in" + " Werkzeug 2.1. Setting it no longer has any effect.", + DeprecationWarning, + stacklevel=2, + ) + + @property + def ident_func(self) -> t.Callable[[], int]: + warnings.warn( + "'ident_func' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + return _get_ident # type: ignore + + @ident_func.setter + def ident_func(self, func: t.Callable[[], int]) -> None: + warnings.warn( + "'ident_func' is deprecated and will be removedin Werkzeug" + " 2.1. Setting it no longer has any effect.", + DeprecationWarning, + stacklevel=2, + ) + + def get_ident(self) -> int: + """Return the context identifier the local objects use internally for + this context. You cannot override this method to change the behavior + but use it to link other context local objects (such as SQLAlchemy's + scoped sessions) to the Werkzeug locals. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. + + .. versionchanged:: 0.7 + You can pass a different ident function to the local manager that + will then be propagated to all the locals passed to the + constructor. + """ + warnings.warn( + "'get_ident' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + return self.ident_func() + + def cleanup(self) -> None: + """Manually clean up the data in the locals for this context. Call + this at the end of the request or use `make_middleware()`. + """ + for local in self.locals: + release_local(local) + + def make_middleware(self, app: "WSGIApplication") -> "WSGIApplication": + """Wrap a WSGI application so that cleaning up happens after + request end. + """ + + def application( + environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + return ClosingIterator(app(environ, start_response), self.cleanup) + + return application + + def middleware(self, func: "WSGIApplication") -> "WSGIApplication": + """Like `make_middleware` but for decorating functions. + + Example usage:: + + @manager.middleware + def application(environ, start_response): + ... + + The difference to `make_middleware` is that the function passed + will have all the arguments copied from the inner application + (name, docstring, module). + """ + return update_wrapper(self.make_middleware(func), func) + + def __repr__(self) -> str: + return f"<{type(self).__name__} storages: {len(self.locals)}>" + + +class _ProxyLookup: + """Descriptor that handles proxied attribute lookup for + :class:`LocalProxy`. + + :param f: The built-in function this attribute is accessed through. + Instead of looking up the special method, the function call + is redone on the object. + :param fallback: Call this method if the proxy is unbound instead of + raising a :exc:`RuntimeError`. + :param class_value: Value to return when accessed from the class. + Used for ``__doc__`` so building docs still works. + """ + + __slots__ = ("bind_f", "fallback", "class_value", "name") + + def __init__( + self, + f: t.Optional[t.Callable] = None, + fallback: t.Optional[t.Callable] = None, + class_value: t.Optional[t.Any] = None, + ) -> None: + bind_f: t.Optional[t.Callable[["LocalProxy", t.Any], t.Callable]] + + if hasattr(f, "__get__"): + # A Python function, can be turned into a bound method. + + def bind_f(instance: "LocalProxy", obj: t.Any) -> t.Callable: + return f.__get__(obj, type(obj)) # type: ignore + + elif f is not None: + # A C function, use partial to bind the first argument. + + def bind_f(instance: "LocalProxy", obj: t.Any) -> t.Callable: + return partial(f, obj) # type: ignore + + else: + # Use getattr, which will produce a bound method. + bind_f = None + + self.bind_f = bind_f + self.fallback = fallback + self.class_value = class_value + + def __set_name__(self, owner: "LocalProxy", name: str) -> None: + self.name = name + + def __get__(self, instance: "LocalProxy", owner: t.Optional[type] = None) -> t.Any: + if instance is None: + if self.class_value is not None: + return self.class_value + + return self + + try: + obj = instance._get_current_object() + except RuntimeError: + if self.fallback is None: + raise + + return self.fallback.__get__(instance, owner) # type: ignore + + if self.bind_f is not None: + return self.bind_f(instance, obj) + + return getattr(obj, self.name) + + def __repr__(self) -> str: + return f"proxy {self.name}" + + def __call__(self, instance: "LocalProxy", *args: t.Any, **kwargs: t.Any) -> t.Any: + """Support calling unbound methods from the class. For example, + this happens with ``copy.copy``, which does + ``type(x).__copy__(x)``. ``type(x)`` can't be proxied, so it + returns the proxy type and descriptor. + """ + return self.__get__(instance, type(instance))(*args, **kwargs) + + +class _ProxyIOp(_ProxyLookup): + """Look up an augmented assignment method on a proxied object. The + method is wrapped to return the proxy instead of the object. + """ + + __slots__ = () + + def __init__( + self, f: t.Optional[t.Callable] = None, fallback: t.Optional[t.Callable] = None + ) -> None: + super().__init__(f, fallback) + + def bind_f(instance: "LocalProxy", obj: t.Any) -> t.Callable: + def i_op(self: t.Any, other: t.Any) -> "LocalProxy": + f(self, other) # type: ignore + return instance + + return i_op.__get__(obj, type(obj)) # type: ignore + + self.bind_f = bind_f + + +def _l_to_r_op(op: F) -> F: + """Swap the argument order to turn an l-op into an r-op.""" + + def r_op(obj: t.Any, other: t.Any) -> t.Any: + return op(other, obj) + + return t.cast(F, r_op) + + +class LocalProxy: + """A proxy to the object bound to a :class:`Local`. All operations + on the proxy are forwarded to the bound object. If no object is + bound, a :exc:`RuntimeError` is raised. + + .. code-block:: python + + from werkzeug.local import Local + l = Local() + + # a proxy to whatever l.user is set to + user = l("user") + + from werkzeug.local import LocalStack + _request_stack = LocalStack() + + # a proxy to _request_stack.top + request = _request_stack() + + # a proxy to the session attribute of the request proxy + session = LocalProxy(lambda: request.session) + + ``__repr__`` and ``__class__`` are forwarded, so ``repr(x)`` and + ``isinstance(x, cls)`` will look like the proxied object. Use + ``issubclass(type(x), LocalProxy)`` to check if an object is a + proxy. + + .. code-block:: python + + repr(user) # + isinstance(user, User) # True + issubclass(type(user), LocalProxy) # True + + :param local: The :class:`Local` or callable that provides the + proxied object. + :param name: The attribute name to look up on a :class:`Local`. Not + used if a callable is given. + + .. versionchanged:: 2.0 + Updated proxied attributes and methods to reflect the current + data model. + + .. versionchanged:: 0.6.1 + The class can be instantiated with a callable. + """ + + __slots__ = ("__local", "__name", "__wrapped__") + + def __init__( + self, + local: t.Union["Local", t.Callable[[], t.Any]], + name: t.Optional[str] = None, + ) -> None: + object.__setattr__(self, "_LocalProxy__local", local) + object.__setattr__(self, "_LocalProxy__name", name) + + if callable(local) and not hasattr(local, "__release_local__"): + # "local" is a callable that is not an instance of Local or + # LocalManager: mark it as a wrapped function. + object.__setattr__(self, "__wrapped__", local) + + def _get_current_object(self) -> t.Any: + """Return the current object. This is useful if you want the real + object behind the proxy at a time for performance reasons or because + you want to pass the object into a different context. + """ + if not hasattr(self.__local, "__release_local__"): # type: ignore + return self.__local() # type: ignore + + try: + return getattr(self.__local, self.__name) # type: ignore + except AttributeError: + name = self.__name # type: ignore + raise RuntimeError(f"no object bound to {name}") from None + + __doc__ = _ProxyLookup( # type: ignore + class_value=__doc__, fallback=lambda self: type(self).__doc__ + ) + # __del__ should only delete the proxy + __repr__ = _ProxyLookup( # type: ignore + repr, fallback=lambda self: f"<{type(self).__name__} unbound>" + ) + __str__ = _ProxyLookup(str) # type: ignore + __bytes__ = _ProxyLookup(bytes) + __format__ = _ProxyLookup() # type: ignore + __lt__ = _ProxyLookup(operator.lt) + __le__ = _ProxyLookup(operator.le) + __eq__ = _ProxyLookup(operator.eq) # type: ignore + __ne__ = _ProxyLookup(operator.ne) # type: ignore + __gt__ = _ProxyLookup(operator.gt) + __ge__ = _ProxyLookup(operator.ge) + __hash__ = _ProxyLookup(hash) # type: ignore + __bool__ = _ProxyLookup(bool, fallback=lambda self: False) + __getattr__ = _ProxyLookup(getattr) + # __getattribute__ triggered through __getattr__ + __setattr__ = _ProxyLookup(setattr) # type: ignore + __delattr__ = _ProxyLookup(delattr) # type: ignore + __dir__ = _ProxyLookup(dir, fallback=lambda self: []) # type: ignore + # __get__ (proxying descriptor not supported) + # __set__ (descriptor) + # __delete__ (descriptor) + # __set_name__ (descriptor) + # __objclass__ (descriptor) + # __slots__ used by proxy itself + # __dict__ (__getattr__) + # __weakref__ (__getattr__) + # __init_subclass__ (proxying metaclass not supported) + # __prepare__ (metaclass) + __class__ = _ProxyLookup(fallback=lambda self: type(self)) # type: ignore + __instancecheck__ = _ProxyLookup(lambda self, other: isinstance(other, self)) + __subclasscheck__ = _ProxyLookup(lambda self, other: issubclass(other, self)) + # __class_getitem__ triggered through __getitem__ + __call__ = _ProxyLookup(lambda self, *args, **kwargs: self(*args, **kwargs)) + __len__ = _ProxyLookup(len) + __length_hint__ = _ProxyLookup(operator.length_hint) + __getitem__ = _ProxyLookup(operator.getitem) + __setitem__ = _ProxyLookup(operator.setitem) + __delitem__ = _ProxyLookup(operator.delitem) + # __missing__ triggered through __getitem__ + __iter__ = _ProxyLookup(iter) + __next__ = _ProxyLookup(next) + __reversed__ = _ProxyLookup(reversed) + __contains__ = _ProxyLookup(operator.contains) + __add__ = _ProxyLookup(operator.add) + __sub__ = _ProxyLookup(operator.sub) + __mul__ = _ProxyLookup(operator.mul) + __matmul__ = _ProxyLookup(operator.matmul) + __truediv__ = _ProxyLookup(operator.truediv) + __floordiv__ = _ProxyLookup(operator.floordiv) + __mod__ = _ProxyLookup(operator.mod) + __divmod__ = _ProxyLookup(divmod) + __pow__ = _ProxyLookup(pow) + __lshift__ = _ProxyLookup(operator.lshift) + __rshift__ = _ProxyLookup(operator.rshift) + __and__ = _ProxyLookup(operator.and_) + __xor__ = _ProxyLookup(operator.xor) + __or__ = _ProxyLookup(operator.or_) + __radd__ = _ProxyLookup(_l_to_r_op(operator.add)) + __rsub__ = _ProxyLookup(_l_to_r_op(operator.sub)) + __rmul__ = _ProxyLookup(_l_to_r_op(operator.mul)) + __rmatmul__ = _ProxyLookup(_l_to_r_op(operator.matmul)) + __rtruediv__ = _ProxyLookup(_l_to_r_op(operator.truediv)) + __rfloordiv__ = _ProxyLookup(_l_to_r_op(operator.floordiv)) + __rmod__ = _ProxyLookup(_l_to_r_op(operator.mod)) + __rdivmod__ = _ProxyLookup(_l_to_r_op(divmod)) + __rpow__ = _ProxyLookup(_l_to_r_op(pow)) + __rlshift__ = _ProxyLookup(_l_to_r_op(operator.lshift)) + __rrshift__ = _ProxyLookup(_l_to_r_op(operator.rshift)) + __rand__ = _ProxyLookup(_l_to_r_op(operator.and_)) + __rxor__ = _ProxyLookup(_l_to_r_op(operator.xor)) + __ror__ = _ProxyLookup(_l_to_r_op(operator.or_)) + __iadd__ = _ProxyIOp(operator.iadd) + __isub__ = _ProxyIOp(operator.isub) + __imul__ = _ProxyIOp(operator.imul) + __imatmul__ = _ProxyIOp(operator.imatmul) + __itruediv__ = _ProxyIOp(operator.itruediv) + __ifloordiv__ = _ProxyIOp(operator.ifloordiv) + __imod__ = _ProxyIOp(operator.imod) + __ipow__ = _ProxyIOp(operator.ipow) + __ilshift__ = _ProxyIOp(operator.ilshift) + __irshift__ = _ProxyIOp(operator.irshift) + __iand__ = _ProxyIOp(operator.iand) + __ixor__ = _ProxyIOp(operator.ixor) + __ior__ = _ProxyIOp(operator.ior) + __neg__ = _ProxyLookup(operator.neg) + __pos__ = _ProxyLookup(operator.pos) + __abs__ = _ProxyLookup(abs) + __invert__ = _ProxyLookup(operator.invert) + __complex__ = _ProxyLookup(complex) + __int__ = _ProxyLookup(int) + __float__ = _ProxyLookup(float) + __index__ = _ProxyLookup(operator.index) + __round__ = _ProxyLookup(round) + __trunc__ = _ProxyLookup(math.trunc) + __floor__ = _ProxyLookup(math.floor) + __ceil__ = _ProxyLookup(math.ceil) + __enter__ = _ProxyLookup() + __exit__ = _ProxyLookup() + __await__ = _ProxyLookup() + __aiter__ = _ProxyLookup() + __anext__ = _ProxyLookup() + __aenter__ = _ProxyLookup() + __aexit__ = _ProxyLookup() + __copy__ = _ProxyLookup(copy.copy) + __deepcopy__ = _ProxyLookup(copy.deepcopy) + # __getnewargs_ex__ (pickle through proxy not supported) + # __getnewargs__ (pickle) + # __getstate__ (pickle) + # __setstate__ (pickle) + # __reduce__ (pickle) + # __reduce_ex__ (pickle) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__init__.py new file mode 100644 index 00000000..6ddcf7f5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__init__.py @@ -0,0 +1,22 @@ +""" +Middleware +========== + +A WSGI middleware is a WSGI application that wraps another application +in order to observe or change its behavior. Werkzeug provides some +middleware for common use cases. + +.. toctree:: + :maxdepth: 1 + + proxy_fix + shared_data + dispatcher + http_proxy + lint + profiler + +The :doc:`interactive debugger ` is also a middleware that can +be applied manually, although it is typically used automatically with +the :doc:`development server `. +""" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..f67f318b48924326ac478ec25aa44400fafd695a GIT binary patch literal 668 zcmYjP!D`$v5cTHLAjm(=HPCt~J=LU3dnl#Q_L4%N7__t2tR*5#LXy3^`J?_)u08jZ zUYb+K+K}#m#LRmddET?|;zCp$e;@Dg&!Vb+&BbXjR=wwy&UsVSk4i1BtIIR|&4l=B zl(MwLNaEdd2=M`Ku0MT-;h6=K0FNMsU`>bFcn4WyhF!$Ktn*n@gcDjA2RhhopX?-qmnPir8ht!W3=BzGtyl%aX3v#Wb5dJ9i?Zc-Em48#zc^z^nQPyDZom literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/dispatcher.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/dispatcher.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..79134c70cc933efc57dd07c117eb5ca0dc778faa GIT binary patch literal 2727 zcmZ`*TW=dh6yBRJ**c{{K`2N_qrQ|#sasJAglSPj5|WfQL`@K?6|oxcjFWBGyPKJD zQWxi`ec(S7r1p`&w68q%Cr|<6JF{`@URY~qXXcza*YBJ$pPvsMJb%4@!WS_6lNPg& zkHu}gdJ}_ix{h##m%3d~dJlc|1y+6<3~Jq)OOycfdbe)pHOw2`hU;uNqAnWG9MO2{ zb(_N5b(Wg^LEt#yN>QXq%uSMKY%S3RH}RoV;jQ;RVYqjgXf{ZMNaYDvlEq4LBQ@hp zC)q(N*-yJ0Ta3>LHHX|VF_Em9$-}`gHAw;H+(6emN1z}dW=0BTPxkv#$;_}H@84xG z?@+hHaD~PBU;vZlV?H2BuLeTGLw3lICF5a_$B$$t z*vbx!#+S3c%Ap!l5{C&(GIoa_^W9h_g<+L9IXs5xOyxsT8G?tFJ(ZtmIHX`DKH$xm zl1D?StzjaWxKh9}O{xa=9L^j|)kbjTR6jgA59;RLy}Q=FJG-o(z+G#GKFo)yU_HsK z0KxjX0@o;{C}CSC0$MI#<3(~AF|(J!1U_SG7-2Kz&&I%JSWl4 zWg;SAmULzhxnbR^B1o2ENk*kPtIyjs}5U@N;AlryU-zo8QDGawVR;XMIW5W8fMZq9BI5fzxHj)cqA_J`93x%Fi zE!pPY-cA)=#Zq}J)8&xNBA8X)!8r(hJfaL()lE;)iCS;N3BOE0g@3@Y$nh$zOCfRwv0@xZ3~l)#T~q-bg2I5{)*&#x(?UtbL?O+SzRmkt^_|y?KqJep7&f4; z4~R`vkp-0tXNoLAci25%=*qrA$$s(}_5CL5t9qZPMpaZ|wv~^>E%~JnlgoM~uBX2?7)FL!&%Qv?dtzyP^{mT7;w^M|A8PJO*0 zI{OFd5Es*aF*=sn@s0LZ`*)MxzD|t1TA=$=C*D7i>d_N9Jh(Q!*{)4|Kw~aOWiyJB zEHP1Z17bBUPRFU$-6x-}O)fSy#ZG&|tB6mLH?Xh)?S$|0B1%=6NS#%LYJ&bo2xx;& z+7SGT$=H2i@BEkEsV}_KK=@<-*iqYKf9yPTF>BLz>@PZ}wWFWM{tHj|B6#WTga5P+ z?)r0Q96Wb^_fLbPOT_!av1ffqtXb(b;bGnwH^%$rm*IuDaobH9))%#mJd(rmFz4fJ_^be%5i9v=nD#qBvEH%{}nAJQD z7crD|Z7o^iLk>3l7r;L=tfcW zHCFl)436J&1Fz|Z_<7zX_mX$XYq>4A`Tr@aBoMM%B#`t(Q5ic4zEAcS6-bSi);T z-*khP^N;6w?uV}TcWW+ioBviEb83;~*3GCubt!VToZow}vmUK(uCIQ-wY|~37=bAD np%m>CeUMlH+WM>TNQ&NPLD{@nx%v&|RFnAuYkGBr4L|=s#(W~| literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/http_proxy.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/http_proxy.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fa24fe495d944bc8fe4d0ef3cdcbb6391212f49a GIT binary patch literal 6772 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 R8>@&y1>TkY;BBgB{x9I&6_Ee{ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/lint.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/lint.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..43c2df8347e4d9235697cbc755692b026ef87af0 GIT binary patch literal 12668 zcmb_iOK=?5b?x8G^n5S?K@j{?ZOIlnF*&3t+Ex%*Aw@wVZ3?7G$c(3Gj~derV1St( z@Vy>V=nS01P)d?Ni7S%FAA)Qk4~}vdqSGEalw$x~FFV z&`zo{sBXM}zt8=gd+&26CQ2H9zj_+E-~Xbf{Rd@6e|cmss4GtsR!s=DSIYm?&J z7@^de>KR;}G(b-W2jvoS*d%FYEqc z{|H7r>KWdFk1cQ7JNSOCaSSbIyhCVtXxnHUM{d?TjND=5P9S&0JBr*<OZ&PZ_K^>GJfwSeK-7; zgNb2A_;P2{X?Hg|e%HrBJRZUA$ex4g1w04Y>-wcuuiM3Zt}QO!a(p3r0+a2xRvlM5 zK`%JxcQ-I^;meI)AhAX)$9eg}B}ayC*q2VLhlSTmrFz|Q``EXRE9KlA@7>$Oy(pFD zTD^@;(Oy{%=bVcdE_}(k<#sxLC`)r#ppSv)oY(KXaqi`FS37QB`lTmCtqV0ho>&xa z%U^O^>x-KkJ__u<=xn$`Qre=GJTcG|nZh;S^?V_boNCJ^){G5ru5uyD%5Szi{#}7B z^#!sMcS2W$x07X|V3IcfO19x?(R}crEqVd%VT&d;`UA}`~9NWQ4eor@zwi?`>>8@Ph|0*MI-sjrP(#*$(}48`wX0#h3RU`eHru z`zz-&LOtIBo!44kY9*Op#S^*HkiPP@@JiuUg*Sn{Rw^Ju^yMe z3a#~y|G@8Hf>sDR6&9*Qm0q-~HB%g-^env&(`$Heyx6$Ja-m6GUqrQ}PMTiP4gCZj z<2QoNrA39KKl=VB^i&GK_cS)zYzcv#E(RwIwnf}itpD1r1wi9J$cdqtEK zQBvZbrH^&5>{U=!CJBxlNocE4@pSCRWL&-;Z1lrBq43@A!eb-OOHPU-m`00;C;d^H z9zF!pNCRwqlehJ;zJRSOG*wp&VoATVEIxxqyEg|s(T4DBHZP!($wAYjnUOiv(*`vR zw!7~P{vB%6)tGhhX{A(Z@%etU9k>+5;$uTysK5PFWAbmQ6hwX5+hrOe5~qinXKm|w?Hg!yK?(cZ zLUeNETuu|1BBq8C6||S5r${RUV^~zjOBd%*lI;xU%8W6-1Ek`qN3(esttI1hFhT`? z)m@8D8;&spt(F*?S4*3SRp=za)S9qvW5;}iwX*WE7NRqYK$as&68NLXtd8PQVf2|y zPCT}6ozn$riS56%<>mACMW z{Y>O8co)`4Rs<^tDY!CQiAD^(sW>BWHbOFZG$ls z5e@W5dO}9VLNv`v36$Ow^@jo!e5O{j7?;E*v{^zXT$5^qS26zXIlqRo6+8*GR6s4G zv*!MSj&l#u(~Nnx1gkJZZAVYZocF0_By(8q^yTWlq_^9T8IPpbIM1)>p1y1x)c}3- zejx$PW&)aR0OnB%P-OUP$CbB$@I2qUOI)ykGp3`C^R3l>u%2)lQA_%x^pJK*_9+lN z0Od4cFs2j(7~N!I04P>NrPM>ii#O>tPCUGM@1Z=Qn!Fwz8lBou1c*OCqdhWbNX?|r zNr`0Kzhfxg2bY;URtTiDJthkZJW&XMJPQEvC7K*TYjF*)I8R1);3=T+hg3X1aZ-T< zaGK2lDrFuoLIS0|^H;5ErTwTVwh6G2Qs(c+){VA=SqPM*sOl@@ALc2r!k9@TT3 z?FsD1{XWO2Y)ryZ!fVQQ>jt%i(_X*!d`Cs9Y zM3WlMwrbc$J~Q_K^r!Yc03s_$20GgGS3qKT0G}YkG^>#VXAK9i4eOm!3h^RkiKq0w zXKd+P1_YP3mfzO5OgMT9o*CMn^#fxI_PdvZ-T&7E11kI?+UB<0_Nb1=(S!qu8CPGWc37qEH2Fa`g;4RTjSQ^RIGyE)lgqaTUhg3}{}y?yQmua#ZnMBG8YyF`waWrwW@n6?2-;T{uytJ9{O z*W)>N-LSP>ve;aKTz#9$a-AN0rh@2D@y86M z$OTd>C=MtqPk56&;TRgmFZ?Nu5>E;8ISAwQteR@cvAOPVLfb!ZJAHpQ^U!Sm4v!?Q z59TqT7r{Iw{DF-iEN!HWPc3*+Dxc;}3niyeX3+DAWm)<(m<#r_Vf8!Y7$zAag z6@dGqMM5YOOH{99TOFEWT;RmT`S)7>1_e6y!szT7?qO75G2bKg%G8W9M&{t8BQ!9^&LEt zifmJzk@4$FrD|3WR6i%EzJ+J(NAz?VkNgL`QgERn2LvEsQ9=#@99SOY7VJ(Vu{(1< zaO#?kr-)RZ;0M4+0ghWLDXf+K3i1_yV%bb;ihk9fq;_5zp)&e7LDs%=`^IqVZX{wn5#Phc$_bgdkTVbR zNRtFvq{?5aO=6=B+eB_<4mFa`%kQ>Bno?hqrmN6}s@pYR?%j4Y{X7O+U|`W2KW;73q;L?*B} zAlX6D%M@rH9-n6hYs)+kRJ95)?wt(b9+F8snSVq=xwbXLQdT$6cPt9}JTicmC_TYxpb+t+ z0b~VwO`_M2&}(X7{@4Iw8IC)!#4mtb(l)<9n*#%DybYt5>4oS#Ggq=^a-ydmR+l(5 z@L*Xxx0oCpuiXmkPYB<0@S;|XtGDOB_RjpB#pc`di`QOav_ zl9wiN{gV<$0LU&AgaNQY&d$LT4%kyM2*^-5TI92IbYd4rjeP)SGQyE`H9<6KmbU+1 zOU-MKg7W%%KJa1*yqL8v(0FWbz+w>JMXSn4tvxWd^{@y|{~2l~ zvKqEo!mWI04`A7ZrM@oz33Ef*tKw_FMC-|s)_GVrg)JMc5%?m>A^!_$Tcv-f3)o1o zFNU)k6n4swU}M2<`8jG1WHtAH4k-Z31bto)D+4nuZ5uz-1&MioesQC88=f-+3V2@Ndq>qhfBM7j`B`Ouv6Bf(@7(U4?reNhnJOD zTiA(Y4fW_vQme^Im5q^pG>HL1S$lnKT@R`?SjMdygeN(CNXq*v?lno=4XQ`S_wHZH zA$6c-HuuRh8|NhM9))b{$Az}!!x)hXWE>^Zg4P`8ctzry)V0(GYQS6}Eg4j&GC<8+ z){07$FgXyDiV&~Hq*@)@QFJXpe2d1S=vo)|JP@ajbG$jb1P>xK-;{eb@Ek^c0}3chJ7HWoh(q1xdH%*mgkZjL5iq{;Bcsy!bQBJgVLG-F3#P0F2NQAKrpTDvsd!2rmpx@;B4Ny0}mo`c;FomQ^L-9Qv z5lSNZ5mViys(j#w=$3jY`Jn!kru9C(#x<7sW0Wlr{hUEU1I>`h&AKVkMHS;kP=+ce zBa}4MGqh4l@E&mFu-`}<-p7; zfnSCKs%)&(8H%SI0bzhU0Psh^%^1K!U&Y-INHSbB#DxYYY{Q@$bDf-Z9O=ULAMQt_Z=7k(X|t7dxU?=jY#aE{3pr1kq@X~{0QJN zp?i`;4|JPOgM2PH4ccuuKa5{TC->z_o(IVCvB@`5;`};nmi?{-k?JqtnZzUi4X@

    P+i~{Pk_eoIQ5N8v=Zdw8tB6txh-^(A>J~BUq3vvLy1>b?MJcN>P*9`w()!>AL z0iWb;8mTibRf@fXeH2~15+J>dOP2_1fmY!H_z2}K zJi{LmJw4Cik;IC0Zv#k%Y?v4M2sjU~sR`@^fvB$K4fqNl-OD2X)Ig){Cd@(Gyk#b1 z6oFy>2xY)w0mLkC9{j+Fb6Ahe53$W8IB^`-he_$SiH#zpQd)S8I8t4QAR>-Vrb;vO zI1X12ggt%M0eDdUu8R(M;pI`6{Y$6E6~zb$|K0mZp9l0NkNb%7{S(U0t11#w;=A-3 z*Qbvy6&PYK{)?z@RLAF`c#dq=_%O2@EPd$RQ7!si;yV&Z8tcVsBL6IwiMBcWiDAv^ z(JQ<7Fb(e2UnNQ1k+0RCF}x^Zrknghm@&vxJJR$KuRm~YpM<5{h}p}h*uW0yw+t@{1Ok}&9ilDcFLTp z8}J`n`pl<>S@~7vi&MvEOM=?f96{5L^SGf3GU53G@?maL&}`xgZe@4cOLe}PEm-H; zsjr9$w^8-nkdCU~f&&fR=y+mlH4Hb{x!$nI%I3qyo$qhlnr~jcHh=Z2*B9PuRQX=4 zTm|apHbgb-#}VX0i3{X!q)An%oZa&bVDq>j44xDe^;5W(#EhaT;vGdVw7UJaC$?Wz n*RNj#IcV}lysRqucF8bRZwg)F&z!QRtYgLMrRq$zT)p)_-l+H@ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/profiler.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/profiler.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..5553007b27184502926eddb2e7732e3954166184 GIT binary patch literal 4920 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 GyYxTq*N2e+ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/proxy_fix.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/__pycache__/proxy_fix.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7817c8bf5ba119f73a2d78c4403315e84649396f GIT binary patch literal 6149 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 None: + self.app = app + self.mounts = mounts or {} + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + script = environ.get("PATH_INFO", "") + path_info = "" + + while "/" in script: + if script in self.mounts: + app = self.mounts[script] + break + + script, last_item = script.rsplit("/", 1) + path_info = f"/{last_item}{path_info}" + else: + app = self.mounts.get(script, self.app) + + original_script_name = environ.get("SCRIPT_NAME", "") + environ["SCRIPT_NAME"] = original_script_name + script + environ["PATH_INFO"] = path_info + return app(environ, start_response) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/http_proxy.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/http_proxy.py new file mode 100644 index 00000000..1cde458d --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/http_proxy.py @@ -0,0 +1,230 @@ +""" +Basic HTTP Proxy +================ + +.. autoclass:: ProxyMiddleware + +:copyright: 2007 Pallets +:license: BSD-3-Clause +""" +import typing as t +from http import client + +from ..datastructures import EnvironHeaders +from ..http import is_hop_by_hop_header +from ..urls import url_parse +from ..urls import url_quote +from ..wsgi import get_input_stream + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class ProxyMiddleware: + """Proxy requests under a path to an external server, routing other + requests to the app. + + This middleware can only proxy HTTP requests, as HTTP is the only + protocol handled by the WSGI server. Other protocols, such as + WebSocket requests, cannot be proxied at this layer. This should + only be used for development, in production a real proxy server + should be used. + + The middleware takes a dict mapping a path prefix to a dict + describing the host to be proxied to:: + + app = ProxyMiddleware(app, { + "/static/": { + "target": "http://127.0.0.1:5001/", + } + }) + + Each host has the following options: + + ``target``: + The target URL to dispatch to. This is required. + ``remove_prefix``: + Whether to remove the prefix from the URL before dispatching it + to the target. The default is ``False``. + ``host``: + ``""`` (default): + The host header is automatically rewritten to the URL of the + target. + ``None``: + The host header is unmodified from the client request. + Any other value: + The host header is overwritten with the value. + ``headers``: + A dictionary of headers to be sent with the request to the + target. The default is ``{}``. + ``ssl_context``: + A :class:`ssl.SSLContext` defining how to verify requests if the + target is HTTPS. The default is ``None``. + + In the example above, everything under ``"/static/"`` is proxied to + the server on port 5001. The host header is rewritten to the target, + and the ``"/static/"`` prefix is removed from the URLs. + + :param app: The WSGI application to wrap. + :param targets: Proxy target configurations. See description above. + :param chunk_size: Size of chunks to read from input stream and + write to target. + :param timeout: Seconds before an operation to a target fails. + + .. versionadded:: 0.14 + """ + + def __init__( + self, + app: "WSGIApplication", + targets: t.Mapping[str, t.Dict[str, t.Any]], + chunk_size: int = 2 << 13, + timeout: int = 10, + ) -> None: + def _set_defaults(opts: t.Dict[str, t.Any]) -> t.Dict[str, t.Any]: + opts.setdefault("remove_prefix", False) + opts.setdefault("host", "") + opts.setdefault("headers", {}) + opts.setdefault("ssl_context", None) + return opts + + self.app = app + self.targets = { + f"/{k.strip('/')}/": _set_defaults(v) for k, v in targets.items() + } + self.chunk_size = chunk_size + self.timeout = timeout + + def proxy_to( + self, opts: t.Dict[str, t.Any], path: str, prefix: str + ) -> "WSGIApplication": + target = url_parse(opts["target"]) + host = t.cast(str, target.ascii_host) + + def application( + environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + headers = list(EnvironHeaders(environ).items()) + headers[:] = [ + (k, v) + for k, v in headers + if not is_hop_by_hop_header(k) + and k.lower() not in ("content-length", "host") + ] + headers.append(("Connection", "close")) + + if opts["host"] == "": + headers.append(("Host", host)) + elif opts["host"] is None: + headers.append(("Host", environ["HTTP_HOST"])) + else: + headers.append(("Host", opts["host"])) + + headers.extend(opts["headers"].items()) + remote_path = path + + if opts["remove_prefix"]: + remote_path = remote_path[len(prefix) :].lstrip("/") + remote_path = f"{target.path.rstrip('/')}/{remote_path}" + + content_length = environ.get("CONTENT_LENGTH") + chunked = False + + if content_length not in ("", None): + headers.append(("Content-Length", content_length)) # type: ignore + elif content_length is not None: + headers.append(("Transfer-Encoding", "chunked")) + chunked = True + + try: + if target.scheme == "http": + con = client.HTTPConnection( + host, target.port or 80, timeout=self.timeout + ) + elif target.scheme == "https": + con = client.HTTPSConnection( + host, + target.port or 443, + timeout=self.timeout, + context=opts["ssl_context"], + ) + else: + raise RuntimeError( + "Target scheme must be 'http' or 'https', got" + f" {target.scheme!r}." + ) + + con.connect() + remote_url = url_quote(remote_path) + querystring = environ["QUERY_STRING"] + + if querystring: + remote_url = f"{remote_url}?{querystring}" + + con.putrequest(environ["REQUEST_METHOD"], remote_url, skip_host=True) + + for k, v in headers: + if k.lower() == "connection": + v = "close" + + con.putheader(k, v) + + con.endheaders() + stream = get_input_stream(environ) + + while True: + data = stream.read(self.chunk_size) + + if not data: + break + + if chunked: + con.send(b"%x\r\n%s\r\n" % (len(data), data)) + else: + con.send(data) + + resp = con.getresponse() + except OSError: + from ..exceptions import BadGateway + + return BadGateway()(environ, start_response) + + start_response( + f"{resp.status} {resp.reason}", + [ + (k.title(), v) + for k, v in resp.getheaders() + if not is_hop_by_hop_header(k) + ], + ) + + def read() -> t.Iterator[bytes]: + while True: + try: + data = resp.read(self.chunk_size) + except OSError: + break + + if not data: + break + + yield data + + return read() + + return application + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + path = environ["PATH_INFO"] + app = self.app + + for prefix, opts in self.targets.items(): + if path.startswith(prefix): + app = self.proxy_to(opts, path, prefix) + break + + return app(environ, start_response) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/lint.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/lint.py new file mode 100644 index 00000000..c74703b2 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/lint.py @@ -0,0 +1,420 @@ +""" +WSGI Protocol Linter +==================== + +This module provides a middleware that performs sanity checks on the +behavior of the WSGI server and application. It checks that the +:pep:`3333` WSGI spec is properly implemented. It also warns on some +common HTTP errors such as non-empty responses for 304 status codes. + +.. autoclass:: LintMiddleware + +:copyright: 2007 Pallets +:license: BSD-3-Clause +""" +import typing as t +from types import TracebackType +from urllib.parse import urlparse +from warnings import warn + +from ..datastructures import Headers +from ..http import is_entity_header +from ..wsgi import FileWrapper + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class WSGIWarning(Warning): + """Warning class for WSGI warnings.""" + + +class HTTPWarning(Warning): + """Warning class for HTTP warnings.""" + + +def check_type(context: str, obj: object, need: t.Type = str) -> None: + if type(obj) is not need: + warn( + f"{context!r} requires {need.__name__!r}, got {type(obj).__name__!r}.", + WSGIWarning, + stacklevel=3, + ) + + +class InputStream: + def __init__(self, stream: t.IO[bytes]) -> None: + self._stream = stream + + def read(self, *args: t.Any) -> bytes: + if len(args) == 0: + warn( + "WSGI does not guarantee an EOF marker on the input stream, thus making" + " calls to 'wsgi.input.read()' unsafe. Conforming servers may never" + " return from this call.", + WSGIWarning, + stacklevel=2, + ) + elif len(args) != 1: + warn( + "Too many parameters passed to 'wsgi.input.read()'.", + WSGIWarning, + stacklevel=2, + ) + return self._stream.read(*args) + + def readline(self, *args: t.Any) -> bytes: + if len(args) == 0: + warn( + "Calls to 'wsgi.input.readline()' without arguments are unsafe. Use" + " 'wsgi.input.read()' instead.", + WSGIWarning, + stacklevel=2, + ) + elif len(args) == 1: + warn( + "'wsgi.input.readline()' was called with a size hint. WSGI does not" + " support this, although it's available on all major servers.", + WSGIWarning, + stacklevel=2, + ) + else: + raise TypeError("Too many arguments passed to 'wsgi.input.readline()'.") + return self._stream.readline(*args) + + def __iter__(self) -> t.Iterator[bytes]: + try: + return iter(self._stream) + except TypeError: + warn("'wsgi.input' is not iterable.", WSGIWarning, stacklevel=2) + return iter(()) + + def close(self) -> None: + warn("The application closed the input stream!", WSGIWarning, stacklevel=2) + self._stream.close() + + +class ErrorStream: + def __init__(self, stream: t.IO[str]) -> None: + self._stream = stream + + def write(self, s: str) -> None: + check_type("wsgi.error.write()", s, str) + self._stream.write(s) + + def flush(self) -> None: + self._stream.flush() + + def writelines(self, seq: t.Iterable[str]) -> None: + for line in seq: + self.write(line) + + def close(self) -> None: + warn("The application closed the error stream!", WSGIWarning, stacklevel=2) + self._stream.close() + + +class GuardedWrite: + def __init__(self, write: t.Callable[[bytes], None], chunks: t.List[int]) -> None: + self._write = write + self._chunks = chunks + + def __call__(self, s: bytes) -> None: + check_type("write()", s, bytes) + self._write(s) + self._chunks.append(len(s)) + + +class GuardedIterator: + def __init__( + self, + iterator: t.Iterable[bytes], + headers_set: t.Tuple[int, Headers], + chunks: t.List[int], + ) -> None: + self._iterator = iterator + self._next = iter(iterator).__next__ + self.closed = False + self.headers_set = headers_set + self.chunks = chunks + + def __iter__(self) -> "GuardedIterator": + return self + + def __next__(self) -> bytes: + if self.closed: + warn("Iterated over closed 'app_iter'.", WSGIWarning, stacklevel=2) + + rv = self._next() + + if not self.headers_set: + warn( + "The application returned before it started the response.", + WSGIWarning, + stacklevel=2, + ) + + check_type("application iterator items", rv, bytes) + self.chunks.append(len(rv)) + return rv + + def close(self) -> None: + self.closed = True + + if hasattr(self._iterator, "close"): + self._iterator.close() # type: ignore + + if self.headers_set: + status_code, headers = self.headers_set + bytes_sent = sum(self.chunks) + content_length = headers.get("content-length", type=int) + + if status_code == 304: + for key, _value in headers: + key = key.lower() + if key not in ("expires", "content-location") and is_entity_header( + key + ): + warn( + f"Entity header {key!r} found in 304 response.", HTTPWarning + ) + if bytes_sent: + warn("304 responses must not have a body.", HTTPWarning) + elif 100 <= status_code < 200 or status_code == 204: + if content_length != 0: + warn( + f"{status_code} responses must have an empty content length.", + HTTPWarning, + ) + if bytes_sent: + warn(f"{status_code} responses must not have a body.", HTTPWarning) + elif content_length is not None and content_length != bytes_sent: + warn( + "Content-Length and the number of bytes sent to the" + " client do not match.", + WSGIWarning, + ) + + def __del__(self) -> None: + if not self.closed: + try: + warn( + "Iterator was garbage collected before it was closed.", WSGIWarning + ) + except Exception: + pass + + +class LintMiddleware: + """Warns about common errors in the WSGI and HTTP behavior of the + server and wrapped application. Some of the issues it checks are: + + - invalid status codes + - non-bytes sent to the WSGI server + - strings returned from the WSGI application + - non-empty conditional responses + - unquoted etags + - relative URLs in the Location header + - unsafe calls to wsgi.input + - unclosed iterators + + Error information is emitted using the :mod:`warnings` module. + + :param app: The WSGI application to wrap. + + .. code-block:: python + + from werkzeug.middleware.lint import LintMiddleware + app = LintMiddleware(app) + """ + + def __init__(self, app: "WSGIApplication") -> None: + self.app = app + + def check_environ(self, environ: "WSGIEnvironment") -> None: + if type(environ) is not dict: + warn( + "WSGI environment is not a standard Python dict.", + WSGIWarning, + stacklevel=4, + ) + for key in ( + "REQUEST_METHOD", + "SERVER_NAME", + "SERVER_PORT", + "wsgi.version", + "wsgi.input", + "wsgi.errors", + "wsgi.multithread", + "wsgi.multiprocess", + "wsgi.run_once", + ): + if key not in environ: + warn( + f"Required environment key {key!r} not found", + WSGIWarning, + stacklevel=3, + ) + if environ["wsgi.version"] != (1, 0): + warn("Environ is not a WSGI 1.0 environ.", WSGIWarning, stacklevel=3) + + script_name = environ.get("SCRIPT_NAME", "") + path_info = environ.get("PATH_INFO", "") + + if script_name and script_name[0] != "/": + warn( + f"'SCRIPT_NAME' does not start with a slash: {script_name!r}", + WSGIWarning, + stacklevel=3, + ) + + if path_info and path_info[0] != "/": + warn( + f"'PATH_INFO' does not start with a slash: {path_info!r}", + WSGIWarning, + stacklevel=3, + ) + + def check_start_response( + self, + status: str, + headers: t.List[t.Tuple[str, str]], + exc_info: t.Optional[ + t.Tuple[t.Type[BaseException], BaseException, TracebackType] + ], + ) -> t.Tuple[int, Headers]: + check_type("status", status, str) + status_code_str = status.split(None, 1)[0] + + if len(status_code_str) != 3 or not status_code_str.isdigit(): + warn("Status code must be three digits.", WSGIWarning, stacklevel=3) + + if len(status) < 4 or status[3] != " ": + warn( + f"Invalid value for status {status!r}. Valid status strings are three" + " digits, a space and a status explanation.", + WSGIWarning, + stacklevel=3, + ) + + status_code = int(status_code_str) + + if status_code < 100: + warn("Status code < 100 detected.", WSGIWarning, stacklevel=3) + + if type(headers) is not list: + warn("Header list is not a list.", WSGIWarning, stacklevel=3) + + for item in headers: + if type(item) is not tuple or len(item) != 2: + warn("Header items must be 2-item tuples.", WSGIWarning, stacklevel=3) + name, value = item + if type(name) is not str or type(value) is not str: + warn( + "Header keys and values must be strings.", WSGIWarning, stacklevel=3 + ) + if name.lower() == "status": + warn( + "The status header is not supported due to" + " conflicts with the CGI spec.", + WSGIWarning, + stacklevel=3, + ) + + if exc_info is not None and not isinstance(exc_info, tuple): + warn("Invalid value for exc_info.", WSGIWarning, stacklevel=3) + + headers = Headers(headers) + self.check_headers(headers) + + return status_code, headers + + def check_headers(self, headers: Headers) -> None: + etag = headers.get("etag") + + if etag is not None: + if etag.startswith(("W/", "w/")): + if etag.startswith("w/"): + warn( + "Weak etag indicator should be upper case.", + HTTPWarning, + stacklevel=4, + ) + + etag = etag[2:] + + if not (etag[:1] == etag[-1:] == '"'): + warn("Unquoted etag emitted.", HTTPWarning, stacklevel=4) + + location = headers.get("location") + + if location is not None: + if not urlparse(location).netloc: + warn( + "Absolute URLs required for location header.", + HTTPWarning, + stacklevel=4, + ) + + def check_iterator(self, app_iter: t.Iterable[bytes]) -> None: + if isinstance(app_iter, bytes): + warn( + "The application returned a bytestring. The response will send one" + " character at a time to the client, which will kill performance." + " Return a list or iterable instead.", + WSGIWarning, + stacklevel=3, + ) + + def __call__(self, *args: t.Any, **kwargs: t.Any) -> t.Iterable[bytes]: + if len(args) != 2: + warn("A WSGI app takes two arguments.", WSGIWarning, stacklevel=2) + + if kwargs: + warn( + "A WSGI app does not take keyword arguments.", WSGIWarning, stacklevel=2 + ) + + environ: "WSGIEnvironment" = args[0] + start_response: "StartResponse" = args[1] + + self.check_environ(environ) + environ["wsgi.input"] = InputStream(environ["wsgi.input"]) + environ["wsgi.errors"] = ErrorStream(environ["wsgi.errors"]) + + # Hook our own file wrapper in so that applications will always + # iterate to the end and we can check the content length. + environ["wsgi.file_wrapper"] = FileWrapper + + headers_set: t.List[t.Any] = [] + chunks: t.List[int] = [] + + def checking_start_response( + *args: t.Any, **kwargs: t.Any + ) -> t.Callable[[bytes], None]: + if len(args) not in {2, 3}: + warn( + f"Invalid number of arguments: {len(args)}, expected 2 or 3.", + WSGIWarning, + stacklevel=2, + ) + + if kwargs: + warn("'start_response' does not take keyword arguments.", WSGIWarning) + + status: str = args[0] + headers: t.List[t.Tuple[str, str]] = args[1] + exc_info: t.Optional[ + t.Tuple[t.Type[BaseException], BaseException, TracebackType] + ] = (args[2] if len(args) == 3 else None) + + headers_set[:] = self.check_start_response(status, headers, exc_info) + return GuardedWrite(start_response(status, headers, exc_info), chunks) + + app_iter = self.app(environ, t.cast("StartResponse", checking_start_response)) + self.check_iterator(app_iter) + return GuardedIterator( + app_iter, t.cast(t.Tuple[int, Headers], headers_set), chunks + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/profiler.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/profiler.py new file mode 100644 index 00000000..200dae03 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/profiler.py @@ -0,0 +1,139 @@ +""" +Application Profiler +==================== + +This module provides a middleware that profiles each request with the +:mod:`cProfile` module. This can help identify bottlenecks in your code +that may be slowing down your application. + +.. autoclass:: ProfilerMiddleware + +:copyright: 2007 Pallets +:license: BSD-3-Clause +""" +import os.path +import sys +import time +import typing as t +from pstats import Stats + +try: + from cProfile import Profile +except ImportError: + from profile import Profile # type: ignore + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class ProfilerMiddleware: + """Wrap a WSGI application and profile the execution of each + request. Responses are buffered so that timings are more exact. + + If ``stream`` is given, :class:`pstats.Stats` are written to it + after each request. If ``profile_dir`` is given, :mod:`cProfile` + data files are saved to that directory, one file per request. + + The filename can be customized by passing ``filename_format``. If + it is a string, it will be formatted using :meth:`str.format` with + the following fields available: + + - ``{method}`` - The request method; GET, POST, etc. + - ``{path}`` - The request path or 'root' should one not exist. + - ``{elapsed}`` - The elapsed time of the request. + - ``{time}`` - The time of the request. + + If it is a callable, it will be called with the WSGI ``environ`` + dict and should return a filename. + + :param app: The WSGI application to wrap. + :param stream: Write stats to this stream. Disable with ``None``. + :param sort_by: A tuple of columns to sort stats by. See + :meth:`pstats.Stats.sort_stats`. + :param restrictions: A tuple of restrictions to filter stats by. See + :meth:`pstats.Stats.print_stats`. + :param profile_dir: Save profile data files to this directory. + :param filename_format: Format string for profile data file names, + or a callable returning a name. See explanation above. + + .. code-block:: python + + from werkzeug.middleware.profiler import ProfilerMiddleware + app = ProfilerMiddleware(app) + + .. versionchanged:: 0.15 + Stats are written even if ``profile_dir`` is given, and can be + disable by passing ``stream=None``. + + .. versionadded:: 0.15 + Added ``filename_format``. + + .. versionadded:: 0.9 + Added ``restrictions`` and ``profile_dir``. + """ + + def __init__( + self, + app: "WSGIApplication", + stream: t.IO[str] = sys.stdout, + sort_by: t.Iterable[str] = ("time", "calls"), + restrictions: t.Iterable[t.Union[str, int, float]] = (), + profile_dir: t.Optional[str] = None, + filename_format: str = "{method}.{path}.{elapsed:.0f}ms.{time:.0f}.prof", + ) -> None: + self._app = app + self._stream = stream + self._sort_by = sort_by + self._restrictions = restrictions + self._profile_dir = profile_dir + self._filename_format = filename_format + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + response_body: t.List[bytes] = [] + + def catching_start_response(status, headers, exc_info=None): # type: ignore + start_response(status, headers, exc_info) + return response_body.append + + def runapp() -> None: + app_iter = self._app( + environ, t.cast("StartResponse", catching_start_response) + ) + response_body.extend(app_iter) + + if hasattr(app_iter, "close"): + app_iter.close() # type: ignore + + profile = Profile() + start = time.time() + profile.runcall(runapp) + body = b"".join(response_body) + elapsed = time.time() - start + + if self._profile_dir is not None: + if callable(self._filename_format): + filename = self._filename_format(environ) + else: + filename = self._filename_format.format( + method=environ["REQUEST_METHOD"], + path=environ["PATH_INFO"].strip("/").replace("/", ".") or "root", + elapsed=elapsed * 1000.0, + time=time.time(), + ) + filename = os.path.join(self._profile_dir, filename) + profile.dump_stats(filename) + + if self._stream is not None: + stats = Stats(profile, stream=self._stream) + stats.sort_stats(*self._sort_by) + print("-" * 80, file=self._stream) + path_info = environ.get("PATH_INFO", "") + print(f"PATH: {path_info!r}", file=self._stream) + stats.print_stats(*self._restrictions) + print(f"{'-' * 80}\n", file=self._stream) + + return [body] diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/proxy_fix.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/proxy_fix.py new file mode 100644 index 00000000..e90b1b34 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/proxy_fix.py @@ -0,0 +1,187 @@ +""" +X-Forwarded-For Proxy Fix +========================= + +This module provides a middleware that adjusts the WSGI environ based on +``X-Forwarded-`` headers that proxies in front of an application may +set. + +When an application is running behind a proxy server, WSGI may see the +request as coming from that server rather than the real client. Proxies +set various headers to track where the request actually came from. + +This middleware should only be used if the application is actually +behind such a proxy, and should be configured with the number of proxies +that are chained in front of it. Not all proxies set all the headers. +Since incoming headers can be faked, you must set how many proxies are +setting each header so the middleware knows what to trust. + +.. autoclass:: ProxyFix + +:copyright: 2007 Pallets +:license: BSD-3-Clause +""" +import typing as t + +from ..http import parse_list_header + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class ProxyFix: + """Adjust the WSGI environ based on ``X-Forwarded-`` that proxies in + front of the application may set. + + - ``X-Forwarded-For`` sets ``REMOTE_ADDR``. + - ``X-Forwarded-Proto`` sets ``wsgi.url_scheme``. + - ``X-Forwarded-Host`` sets ``HTTP_HOST``, ``SERVER_NAME``, and + ``SERVER_PORT``. + - ``X-Forwarded-Port`` sets ``HTTP_HOST`` and ``SERVER_PORT``. + - ``X-Forwarded-Prefix`` sets ``SCRIPT_NAME``. + + You must tell the middleware how many proxies set each header so it + knows what values to trust. It is a security issue to trust values + that came from the client rather than a proxy. + + The original values of the headers are stored in the WSGI + environ as ``werkzeug.proxy_fix.orig``, a dict. + + :param app: The WSGI application to wrap. + :param x_for: Number of values to trust for ``X-Forwarded-For``. + :param x_proto: Number of values to trust for ``X-Forwarded-Proto``. + :param x_host: Number of values to trust for ``X-Forwarded-Host``. + :param x_port: Number of values to trust for ``X-Forwarded-Port``. + :param x_prefix: Number of values to trust for + ``X-Forwarded-Prefix``. + + .. code-block:: python + + from werkzeug.middleware.proxy_fix import ProxyFix + # App is behind one proxy that sets the -For and -Host headers. + app = ProxyFix(app, x_for=1, x_host=1) + + .. versionchanged:: 1.0 + Deprecated code has been removed: + + * The ``num_proxies`` argument and attribute. + * The ``get_remote_addr`` method. + * The environ keys ``orig_remote_addr``, + ``orig_wsgi_url_scheme``, and ``orig_http_host``. + + .. versionchanged:: 0.15 + All headers support multiple values. The ``num_proxies`` + argument is deprecated. Each header is configured with a + separate number of trusted proxies. + + .. versionchanged:: 0.15 + Original WSGI environ values are stored in the + ``werkzeug.proxy_fix.orig`` dict. ``orig_remote_addr``, + ``orig_wsgi_url_scheme``, and ``orig_http_host`` are deprecated + and will be removed in 1.0. + + .. versionchanged:: 0.15 + Support ``X-Forwarded-Port`` and ``X-Forwarded-Prefix``. + + .. versionchanged:: 0.15 + ``X-Forwarded-Host`` and ``X-Forwarded-Port`` modify + ``SERVER_NAME`` and ``SERVER_PORT``. + """ + + def __init__( + self, + app: "WSGIApplication", + x_for: int = 1, + x_proto: int = 1, + x_host: int = 0, + x_port: int = 0, + x_prefix: int = 0, + ) -> None: + self.app = app + self.x_for = x_for + self.x_proto = x_proto + self.x_host = x_host + self.x_port = x_port + self.x_prefix = x_prefix + + def _get_real_value(self, trusted: int, value: t.Optional[str]) -> t.Optional[str]: + """Get the real value from a list header based on the configured + number of trusted proxies. + + :param trusted: Number of values to trust in the header. + :param value: Comma separated list header value to parse. + :return: The real value, or ``None`` if there are fewer values + than the number of trusted proxies. + + .. versionchanged:: 1.0 + Renamed from ``_get_trusted_comma``. + + .. versionadded:: 0.15 + """ + if not (trusted and value): + return None + values = parse_list_header(value) + if len(values) >= trusted: + return values[-trusted] + return None + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + """Modify the WSGI environ based on the various ``Forwarded`` + headers before calling the wrapped application. Store the + original environ values in ``werkzeug.proxy_fix.orig_{key}``. + """ + environ_get = environ.get + orig_remote_addr = environ_get("REMOTE_ADDR") + orig_wsgi_url_scheme = environ_get("wsgi.url_scheme") + orig_http_host = environ_get("HTTP_HOST") + environ.update( + { + "werkzeug.proxy_fix.orig": { + "REMOTE_ADDR": orig_remote_addr, + "wsgi.url_scheme": orig_wsgi_url_scheme, + "HTTP_HOST": orig_http_host, + "SERVER_NAME": environ_get("SERVER_NAME"), + "SERVER_PORT": environ_get("SERVER_PORT"), + "SCRIPT_NAME": environ_get("SCRIPT_NAME"), + } + } + ) + + x_for = self._get_real_value(self.x_for, environ_get("HTTP_X_FORWARDED_FOR")) + if x_for: + environ["REMOTE_ADDR"] = x_for + + x_proto = self._get_real_value( + self.x_proto, environ_get("HTTP_X_FORWARDED_PROTO") + ) + if x_proto: + environ["wsgi.url_scheme"] = x_proto + + x_host = self._get_real_value(self.x_host, environ_get("HTTP_X_FORWARDED_HOST")) + if x_host: + environ["HTTP_HOST"] = x_host + parts = x_host.split(":", 1) + environ["SERVER_NAME"] = parts[0] + if len(parts) == 2: + environ["SERVER_PORT"] = parts[1] + + x_port = self._get_real_value(self.x_port, environ_get("HTTP_X_FORWARDED_PORT")) + if x_port: + host = environ.get("HTTP_HOST") + if host: + parts = host.split(":", 1) + host = parts[0] if len(parts) == 2 else host + environ["HTTP_HOST"] = f"{host}:{x_port}" + environ["SERVER_PORT"] = x_port + + x_prefix = self._get_real_value( + self.x_prefix, environ_get("HTTP_X_FORWARDED_PREFIX") + ) + if x_prefix: + environ["SCRIPT_NAME"] = x_prefix + + return self.app(environ, start_response) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/shared_data.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/shared_data.py new file mode 100644 index 00000000..62da6727 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/middleware/shared_data.py @@ -0,0 +1,320 @@ +""" +Serve Shared Static Files +========================= + +.. autoclass:: SharedDataMiddleware + :members: is_allowed + +:copyright: 2007 Pallets +:license: BSD-3-Clause +""" +import mimetypes +import os +import pkgutil +import posixpath +import typing as t +from datetime import datetime +from datetime import timezone +from io import BytesIO +from time import time +from zlib import adler32 + +from ..filesystem import get_filesystem_encoding +from ..http import http_date +from ..http import is_resource_modified +from ..security import safe_join +from ..utils import get_content_type +from ..wsgi import get_path_info +from ..wsgi import wrap_file + +_TOpener = t.Callable[[], t.Tuple[t.IO[bytes], datetime, int]] +_TLoader = t.Callable[[t.Optional[str]], t.Tuple[t.Optional[str], t.Optional[_TOpener]]] + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class SharedDataMiddleware: + + """A WSGI middleware which provides static content for development + environments or simple server setups. Its usage is quite simple:: + + import os + from werkzeug.middleware.shared_data import SharedDataMiddleware + + app = SharedDataMiddleware(app, { + '/shared': os.path.join(os.path.dirname(__file__), 'shared') + }) + + The contents of the folder ``./shared`` will now be available on + ``http://example.com/shared/``. This is pretty useful during development + because a standalone media server is not required. Files can also be + mounted on the root folder and still continue to use the application because + the shared data middleware forwards all unhandled requests to the + application, even if the requests are below one of the shared folders. + + If `pkg_resources` is available you can also tell the middleware to serve + files from package data:: + + app = SharedDataMiddleware(app, { + '/static': ('myapplication', 'static') + }) + + This will then serve the ``static`` folder in the `myapplication` + Python package. + + The optional `disallow` parameter can be a list of :func:`~fnmatch.fnmatch` + rules for files that are not accessible from the web. If `cache` is set to + `False` no caching headers are sent. + + Currently the middleware does not support non-ASCII filenames. If the + encoding on the file system happens to match the encoding of the URI it may + work but this could also be by accident. We strongly suggest using ASCII + only file names for static files. + + The middleware will guess the mimetype using the Python `mimetype` + module. If it's unable to figure out the charset it will fall back + to `fallback_mimetype`. + + :param app: the application to wrap. If you don't want to wrap an + application you can pass it :exc:`NotFound`. + :param exports: a list or dict of exported files and folders. + :param disallow: a list of :func:`~fnmatch.fnmatch` rules. + :param cache: enable or disable caching headers. + :param cache_timeout: the cache timeout in seconds for the headers. + :param fallback_mimetype: The fallback mimetype for unknown files. + + .. versionchanged:: 1.0 + The default ``fallback_mimetype`` is + ``application/octet-stream``. If a filename looks like a text + mimetype, the ``utf-8`` charset is added to it. + + .. versionadded:: 0.6 + Added ``fallback_mimetype``. + + .. versionchanged:: 0.5 + Added ``cache_timeout``. + """ + + def __init__( + self, + app: "WSGIApplication", + exports: t.Union[ + t.Dict[str, t.Union[str, t.Tuple[str, str]]], + t.Iterable[t.Tuple[str, t.Union[str, t.Tuple[str, str]]]], + ], + disallow: None = None, + cache: bool = True, + cache_timeout: int = 60 * 60 * 12, + fallback_mimetype: str = "application/octet-stream", + ) -> None: + self.app = app + self.exports: t.List[t.Tuple[str, _TLoader]] = [] + self.cache = cache + self.cache_timeout = cache_timeout + + if isinstance(exports, dict): + exports = exports.items() + + for key, value in exports: + if isinstance(value, tuple): + loader = self.get_package_loader(*value) + elif isinstance(value, str): + if os.path.isfile(value): + loader = self.get_file_loader(value) + else: + loader = self.get_directory_loader(value) + else: + raise TypeError(f"unknown def {value!r}") + + self.exports.append((key, loader)) + + if disallow is not None: + from fnmatch import fnmatch + + self.is_allowed = lambda x: not fnmatch(x, disallow) + + self.fallback_mimetype = fallback_mimetype + + def is_allowed(self, filename: str) -> bool: + """Subclasses can override this method to disallow the access to + certain files. However by providing `disallow` in the constructor + this method is overwritten. + """ + return True + + def _opener(self, filename: str) -> _TOpener: + return lambda: ( + open(filename, "rb"), + datetime.fromtimestamp(os.path.getmtime(filename), tz=timezone.utc), + int(os.path.getsize(filename)), + ) + + def get_file_loader(self, filename: str) -> _TLoader: + return lambda x: (os.path.basename(filename), self._opener(filename)) + + def get_package_loader(self, package: str, package_path: str) -> _TLoader: + load_time = datetime.now(timezone.utc) + provider = pkgutil.get_loader(package) + + if hasattr(provider, "get_resource_reader"): + # Python 3 + reader = provider.get_resource_reader(package) # type: ignore + + def loader( + path: t.Optional[str], + ) -> t.Tuple[t.Optional[str], t.Optional[_TOpener]]: + if path is None: + return None, None + + path = safe_join(package_path, path) + + if path is None: + return None, None + + basename = posixpath.basename(path) + + try: + resource = reader.open_resource(path) + except OSError: + return None, None + + if isinstance(resource, BytesIO): + return ( + basename, + lambda: (resource, load_time, len(resource.getvalue())), + ) + + return ( + basename, + lambda: ( + resource, + datetime.fromtimestamp( + os.path.getmtime(resource.name), tz=timezone.utc + ), + os.path.getsize(resource.name), + ), + ) + + else: + # Python 3.6 + package_filename = provider.get_filename(package) # type: ignore + is_filesystem = os.path.exists(package_filename) + root = os.path.join(os.path.dirname(package_filename), package_path) + + def loader( + path: t.Optional[str], + ) -> t.Tuple[t.Optional[str], t.Optional[_TOpener]]: + if path is None: + return None, None + + path = safe_join(root, path) + + if path is None: + return None, None + + basename = posixpath.basename(path) + + if is_filesystem: + if not os.path.isfile(path): + return None, None + + return basename, self._opener(path) + + try: + data = provider.get_data(path) # type: ignore + except OSError: + return None, None + + return basename, lambda: (BytesIO(data), load_time, len(data)) + + return loader + + def get_directory_loader(self, directory: str) -> _TLoader: + def loader( + path: t.Optional[str], + ) -> t.Tuple[t.Optional[str], t.Optional[_TOpener]]: + if path is not None: + path = safe_join(directory, path) + + if path is None: + return None, None + else: + path = directory + + if os.path.isfile(path): + return os.path.basename(path), self._opener(path) + + return None, None + + return loader + + def generate_etag(self, mtime: datetime, file_size: int, real_filename: str) -> str: + if not isinstance(real_filename, bytes): + real_filename = real_filename.encode( # type: ignore + get_filesystem_encoding() + ) + + timestamp = mtime.timestamp() + checksum = adler32(real_filename) & 0xFFFFFFFF # type: ignore + return f"wzsdm-{timestamp}-{file_size}-{checksum}" + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + path = get_path_info(environ) + file_loader = None + + for search_path, loader in self.exports: + if search_path == path: + real_filename, file_loader = loader(None) + + if file_loader is not None: + break + + if not search_path.endswith("/"): + search_path += "/" + + if path.startswith(search_path): + real_filename, file_loader = loader(path[len(search_path) :]) + + if file_loader is not None: + break + + if file_loader is None or not self.is_allowed(real_filename): # type: ignore + return self.app(environ, start_response) + + guessed_type = mimetypes.guess_type(real_filename) # type: ignore + mime_type = get_content_type(guessed_type[0] or self.fallback_mimetype, "utf-8") + f, mtime, file_size = file_loader() + + headers = [("Date", http_date())] + + if self.cache: + timeout = self.cache_timeout + etag = self.generate_etag(mtime, file_size, real_filename) # type: ignore + headers += [ + ("Etag", f'"{etag}"'), + ("Cache-Control", f"max-age={timeout}, public"), + ] + + if not is_resource_modified(environ, etag, last_modified=mtime): + f.close() + start_response("304 Not Modified", headers) + return [] + + headers.append(("Expires", http_date(time() + timeout))) + else: + headers.append(("Cache-Control", "public")) + + headers.extend( + ( + ("Content-Type", mime_type), + ("Content-Length", str(file_size)), + ("Last-Modified", http_date(mtime)), + ) + ) + start_response("200 OK", headers) + return wrap_file(environ, f) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/py.typed b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/py.typed new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/routing.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/routing.py new file mode 100644 index 00000000..ddb8ef9c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/routing.py @@ -0,0 +1,2341 @@ +"""When it comes to combining multiple controller or view functions +(however you want to call them) you need a dispatcher. A simple way +would be applying regular expression tests on the ``PATH_INFO`` and +calling registered callback functions that return the value then. + +This module implements a much more powerful system than simple regular +expression matching because it can also convert values in the URLs and +build URLs. + +Here a simple example that creates a URL map for an application with +two subdomains (www and kb) and some URL rules: + +.. code-block:: python + + m = Map([ + # Static URLs + Rule('/', endpoint='static/index'), + Rule('/about', endpoint='static/about'), + Rule('/help', endpoint='static/help'), + # Knowledge Base + Subdomain('kb', [ + Rule('/', endpoint='kb/index'), + Rule('/browse/', endpoint='kb/browse'), + Rule('/browse//', endpoint='kb/browse'), + Rule('/browse//', endpoint='kb/browse') + ]) + ], default_subdomain='www') + +If the application doesn't use subdomains it's perfectly fine to not set +the default subdomain and not use the `Subdomain` rule factory. The +endpoint in the rules can be anything, for example import paths or +unique identifiers. The WSGI application can use those endpoints to get the +handler for that URL. It doesn't have to be a string at all but it's +recommended. + +Now it's possible to create a URL adapter for one of the subdomains and +build URLs: + +.. code-block:: python + + c = m.bind('example.com') + + c.build("kb/browse", dict(id=42)) + 'http://kb.example.com/browse/42/' + + c.build("kb/browse", dict()) + 'http://kb.example.com/browse/' + + c.build("kb/browse", dict(id=42, page=3)) + 'http://kb.example.com/browse/42/3' + + c.build("static/about") + '/about' + + c.build("static/index", force_external=True) + 'http://www.example.com/' + + c = m.bind('example.com', subdomain='kb') + + c.build("static/about") + 'http://www.example.com/about' + +The first argument to bind is the server name *without* the subdomain. +Per default it will assume that the script is mounted on the root, but +often that's not the case so you can provide the real mount point as +second argument: + +.. code-block:: python + + c = m.bind('example.com', '/applications/example') + +The third argument can be the subdomain, if not given the default +subdomain is used. For more details about binding have a look at the +documentation of the `MapAdapter`. + +And here is how you can match URLs: + +.. code-block:: python + + c = m.bind('example.com') + + c.match("/") + ('static/index', {}) + + c.match("/about") + ('static/about', {}) + + c = m.bind('example.com', '/', 'kb') + + c.match("/") + ('kb/index', {}) + + c.match("/browse/42/23") + ('kb/browse', {'id': 42, 'page': 23}) + +If matching fails you get a ``NotFound`` exception, if the rule thinks +it's a good idea to redirect (for example because the URL was defined +to have a slash at the end but the request was missing that slash) it +will raise a ``RequestRedirect`` exception. Both are subclasses of +``HTTPException`` so you can use those errors as responses in the +application. + +If matching succeeded but the URL rule was incompatible to the given +method (for example there were only rules for ``GET`` and ``HEAD`` but +routing tried to match a ``POST`` request) a ``MethodNotAllowed`` +exception is raised. +""" +import ast +import difflib +import posixpath +import re +import typing +import typing as t +import uuid +import warnings +from pprint import pformat +from string import Template +from threading import Lock +from types import CodeType + +from ._internal import _encode_idna +from ._internal import _get_environ +from ._internal import _to_bytes +from ._internal import _to_str +from ._internal import _wsgi_decoding_dance +from .datastructures import ImmutableDict +from .datastructures import MultiDict +from .exceptions import BadHost +from .exceptions import BadRequest +from .exceptions import HTTPException +from .exceptions import MethodNotAllowed +from .exceptions import NotFound +from .urls import _fast_url_quote +from .urls import url_encode +from .urls import url_join +from .urls import url_quote +from .urls import url_unquote +from .utils import cached_property +from .utils import redirect +from .wsgi import get_host + +if t.TYPE_CHECKING: + import typing_extensions as te + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + from .wrappers.response import Response + +_rule_re = re.compile( + r""" + (?P[^<]*) # static rule data + < + (?: + (?P[a-zA-Z_][a-zA-Z0-9_]*) # converter name + (?:\((?P.*?)\))? # converter arguments + \: # variable delimiter + )? + (?P[a-zA-Z_][a-zA-Z0-9_]*) # variable name + > + """, + re.VERBOSE, +) +_simple_rule_re = re.compile(r"<([^>]+)>") +_converter_args_re = re.compile( + r""" + ((?P\w+)\s*=\s*)? + (?P + True|False| + \d+.\d+| + \d+.| + \d+| + [\w\d_.]+| + [urUR]?(?P"[^"]*?"|'[^']*') + )\s*, + """, + re.VERBOSE, +) + + +_PYTHON_CONSTANTS = {"None": None, "True": True, "False": False} + + +def _pythonize(value: str) -> t.Union[None, bool, int, float, str]: + if value in _PYTHON_CONSTANTS: + return _PYTHON_CONSTANTS[value] + for convert in int, float: + try: + return convert(value) # type: ignore + except ValueError: + pass + if value[:1] == value[-1:] and value[0] in "\"'": + value = value[1:-1] + return str(value) + + +def parse_converter_args(argstr: str) -> t.Tuple[t.Tuple, t.Dict[str, t.Any]]: + argstr += "," + args = [] + kwargs = {} + + for item in _converter_args_re.finditer(argstr): + value = item.group("stringval") + if value is None: + value = item.group("value") + value = _pythonize(value) + if not item.group("name"): + args.append(value) + else: + name = item.group("name") + kwargs[name] = value + + return tuple(args), kwargs + + +def parse_rule(rule: str) -> t.Iterator[t.Tuple[t.Optional[str], t.Optional[str], str]]: + """Parse a rule and return it as generator. Each iteration yields tuples + in the form ``(converter, arguments, variable)``. If the converter is + `None` it's a static url part, otherwise it's a dynamic one. + + :internal: + """ + pos = 0 + end = len(rule) + do_match = _rule_re.match + used_names = set() + while pos < end: + m = do_match(rule, pos) + if m is None: + break + data = m.groupdict() + if data["static"]: + yield None, None, data["static"] + variable = data["variable"] + converter = data["converter"] or "default" + if variable in used_names: + raise ValueError(f"variable name {variable!r} used twice.") + used_names.add(variable) + yield converter, data["args"] or None, variable + pos = m.end() + if pos < end: + remaining = rule[pos:] + if ">" in remaining or "<" in remaining: + raise ValueError(f"malformed url rule: {rule!r}") + yield None, None, remaining + + +class RoutingException(Exception): + """Special exceptions that require the application to redirect, notifying + about missing urls, etc. + + :internal: + """ + + +class RequestRedirect(HTTPException, RoutingException): + """Raise if the map requests a redirect. This is for example the case if + `strict_slashes` are activated and an url that requires a trailing slash. + + The attribute `new_url` contains the absolute destination url. + """ + + code = 308 + + def __init__(self, new_url: str) -> None: + super().__init__(new_url) + self.new_url = new_url + + def get_response( + self, + environ: t.Optional["WSGIEnvironment"] = None, + scope: t.Optional[dict] = None, + ) -> "Response": + return redirect(self.new_url, self.code) + + +class RequestPath(RoutingException): + """Internal exception.""" + + __slots__ = ("path_info",) + + def __init__(self, path_info: str) -> None: + super().__init__() + self.path_info = path_info + + +class RequestAliasRedirect(RoutingException): # noqa: B903 + """This rule is an alias and wants to redirect to the canonical URL.""" + + def __init__(self, matched_values: t.Mapping[str, t.Any]) -> None: + super().__init__() + self.matched_values = matched_values + + +class BuildError(RoutingException, LookupError): + """Raised if the build system cannot find a URL for an endpoint with the + values provided. + """ + + def __init__( + self, + endpoint: str, + values: t.Mapping[str, t.Any], + method: t.Optional[str], + adapter: t.Optional["MapAdapter"] = None, + ) -> None: + super().__init__(endpoint, values, method) + self.endpoint = endpoint + self.values = values + self.method = method + self.adapter = adapter + + @cached_property + def suggested(self) -> t.Optional["Rule"]: + return self.closest_rule(self.adapter) + + def closest_rule(self, adapter: t.Optional["MapAdapter"]) -> t.Optional["Rule"]: + def _score_rule(rule: "Rule") -> float: + return sum( + [ + 0.98 + * difflib.SequenceMatcher( + None, rule.endpoint, self.endpoint + ).ratio(), + 0.01 * bool(set(self.values or ()).issubset(rule.arguments)), + 0.01 * bool(rule.methods and self.method in rule.methods), + ] + ) + + if adapter and adapter.map._rules: + return max(adapter.map._rules, key=_score_rule) + + return None + + def __str__(self) -> str: + message = [f"Could not build url for endpoint {self.endpoint!r}"] + if self.method: + message.append(f" ({self.method!r})") + if self.values: + message.append(f" with values {sorted(self.values)!r}") + message.append(".") + if self.suggested: + if self.endpoint == self.suggested.endpoint: + if ( + self.method + and self.suggested.methods is not None + and self.method not in self.suggested.methods + ): + message.append( + " Did you mean to use methods" + f" {sorted(self.suggested.methods)!r}?" + ) + missing_values = self.suggested.arguments.union( + set(self.suggested.defaults or ()) + ) - set(self.values.keys()) + if missing_values: + message.append( + f" Did you forget to specify values {sorted(missing_values)!r}?" + ) + else: + message.append(f" Did you mean {self.suggested.endpoint!r} instead?") + return "".join(message) + + +class WebsocketMismatch(BadRequest): + """The only matched rule is either a WebSocket and the request is + HTTP, or the rule is HTTP and the request is a WebSocket. + """ + + +class ValidationError(ValueError): + """Validation error. If a rule converter raises this exception the rule + does not match the current URL and the next URL is tried. + """ + + +class RuleFactory: + """As soon as you have more complex URL setups it's a good idea to use rule + factories to avoid repetitive tasks. Some of them are builtin, others can + be added by subclassing `RuleFactory` and overriding `get_rules`. + """ + + def get_rules(self, map: "Map") -> t.Iterable["Rule"]: + """Subclasses of `RuleFactory` have to override this method and return + an iterable of rules.""" + raise NotImplementedError() + + +class Subdomain(RuleFactory): + """All URLs provided by this factory have the subdomain set to a + specific domain. For example if you want to use the subdomain for + the current language this can be a good setup:: + + url_map = Map([ + Rule('/', endpoint='#select_language'), + Subdomain('', [ + Rule('/', endpoint='index'), + Rule('/about', endpoint='about'), + Rule('/help', endpoint='help') + ]) + ]) + + All the rules except for the ``'#select_language'`` endpoint will now + listen on a two letter long subdomain that holds the language code + for the current request. + """ + + def __init__(self, subdomain: str, rules: t.Iterable[RuleFactory]) -> None: + self.subdomain = subdomain + self.rules = rules + + def get_rules(self, map: "Map") -> t.Iterator["Rule"]: + for rulefactory in self.rules: + for rule in rulefactory.get_rules(map): + rule = rule.empty() + rule.subdomain = self.subdomain + yield rule + + +class Submount(RuleFactory): + """Like `Subdomain` but prefixes the URL rule with a given string:: + + url_map = Map([ + Rule('/', endpoint='index'), + Submount('/blog', [ + Rule('/', endpoint='blog/index'), + Rule('/entry/', endpoint='blog/show') + ]) + ]) + + Now the rule ``'blog/show'`` matches ``/blog/entry/``. + """ + + def __init__(self, path: str, rules: t.Iterable[RuleFactory]) -> None: + self.path = path.rstrip("/") + self.rules = rules + + def get_rules(self, map: "Map") -> t.Iterator["Rule"]: + for rulefactory in self.rules: + for rule in rulefactory.get_rules(map): + rule = rule.empty() + rule.rule = self.path + rule.rule + yield rule + + +class EndpointPrefix(RuleFactory): + """Prefixes all endpoints (which must be strings for this factory) with + another string. This can be useful for sub applications:: + + url_map = Map([ + Rule('/', endpoint='index'), + EndpointPrefix('blog/', [Submount('/blog', [ + Rule('/', endpoint='index'), + Rule('/entry/', endpoint='show') + ])]) + ]) + """ + + def __init__(self, prefix: str, rules: t.Iterable[RuleFactory]) -> None: + self.prefix = prefix + self.rules = rules + + def get_rules(self, map: "Map") -> t.Iterator["Rule"]: + for rulefactory in self.rules: + for rule in rulefactory.get_rules(map): + rule = rule.empty() + rule.endpoint = self.prefix + rule.endpoint + yield rule + + +class RuleTemplate: + """Returns copies of the rules wrapped and expands string templates in + the endpoint, rule, defaults or subdomain sections. + + Here a small example for such a rule template:: + + from werkzeug.routing import Map, Rule, RuleTemplate + + resource = RuleTemplate([ + Rule('/$name/', endpoint='$name.list'), + Rule('/$name/', endpoint='$name.show') + ]) + + url_map = Map([resource(name='user'), resource(name='page')]) + + When a rule template is called the keyword arguments are used to + replace the placeholders in all the string parameters. + """ + + def __init__(self, rules: t.Iterable["Rule"]) -> None: + self.rules = list(rules) + + def __call__(self, *args: t.Any, **kwargs: t.Any) -> "RuleTemplateFactory": + return RuleTemplateFactory(self.rules, dict(*args, **kwargs)) + + +class RuleTemplateFactory(RuleFactory): + """A factory that fills in template variables into rules. Used by + `RuleTemplate` internally. + + :internal: + """ + + def __init__( + self, rules: t.Iterable[RuleFactory], context: t.Dict[str, t.Any] + ) -> None: + self.rules = rules + self.context = context + + def get_rules(self, map: "Map") -> t.Iterator["Rule"]: + for rulefactory in self.rules: + for rule in rulefactory.get_rules(map): + new_defaults = subdomain = None + if rule.defaults: + new_defaults = {} + for key, value in rule.defaults.items(): + if isinstance(value, str): + value = Template(value).substitute(self.context) + new_defaults[key] = value + if rule.subdomain is not None: + subdomain = Template(rule.subdomain).substitute(self.context) + new_endpoint = rule.endpoint + if isinstance(new_endpoint, str): + new_endpoint = Template(new_endpoint).substitute(self.context) + yield Rule( + Template(rule.rule).substitute(self.context), + new_defaults, + subdomain, + rule.methods, + rule.build_only, + new_endpoint, + rule.strict_slashes, + ) + + +def _prefix_names(src: str) -> ast.stmt: + """ast parse and prefix names with `.` to avoid collision with user vars""" + tree = ast.parse(src).body[0] + if isinstance(tree, ast.Expr): + tree = tree.value # type: ignore + for node in ast.walk(tree): + if isinstance(node, ast.Name): + node.id = f".{node.id}" + return tree + + +_CALL_CONVERTER_CODE_FMT = "self._converters[{elem!r}].to_url()" +_IF_KWARGS_URL_ENCODE_CODE = """\ +if kwargs: + q = '?' + params = self._encode_query_vars(kwargs) +else: + q = params = '' +""" +_IF_KWARGS_URL_ENCODE_AST = _prefix_names(_IF_KWARGS_URL_ENCODE_CODE) +_URL_ENCODE_AST_NAMES = (_prefix_names("q"), _prefix_names("params")) + + +class Rule(RuleFactory): + """A Rule represents one URL pattern. There are some options for `Rule` + that change the way it behaves and are passed to the `Rule` constructor. + Note that besides the rule-string all arguments *must* be keyword arguments + in order to not break the application on Werkzeug upgrades. + + `string` + Rule strings basically are just normal URL paths with placeholders in + the format ```` where the converter and the + arguments are optional. If no converter is defined the `default` + converter is used which means `string` in the normal configuration. + + URL rules that end with a slash are branch URLs, others are leaves. + If you have `strict_slashes` enabled (which is the default), all + branch URLs that are matched without a trailing slash will trigger a + redirect to the same URL with the missing slash appended. + + The converters are defined on the `Map`. + + `endpoint` + The endpoint for this rule. This can be anything. A reference to a + function, a string, a number etc. The preferred way is using a string + because the endpoint is used for URL generation. + + `defaults` + An optional dict with defaults for other rules with the same endpoint. + This is a bit tricky but useful if you want to have unique URLs:: + + url_map = Map([ + Rule('/all/', defaults={'page': 1}, endpoint='all_entries'), + Rule('/all/page/', endpoint='all_entries') + ]) + + If a user now visits ``http://example.com/all/page/1`` he will be + redirected to ``http://example.com/all/``. If `redirect_defaults` is + disabled on the `Map` instance this will only affect the URL + generation. + + `subdomain` + The subdomain rule string for this rule. If not specified the rule + only matches for the `default_subdomain` of the map. If the map is + not bound to a subdomain this feature is disabled. + + Can be useful if you want to have user profiles on different subdomains + and all subdomains are forwarded to your application:: + + url_map = Map([ + Rule('/', subdomain='', endpoint='user/homepage'), + Rule('/stats', subdomain='', endpoint='user/stats') + ]) + + `methods` + A sequence of http methods this rule applies to. If not specified, all + methods are allowed. For example this can be useful if you want different + endpoints for `POST` and `GET`. If methods are defined and the path + matches but the method matched against is not in this list or in the + list of another rule for that path the error raised is of the type + `MethodNotAllowed` rather than `NotFound`. If `GET` is present in the + list of methods and `HEAD` is not, `HEAD` is added automatically. + + `strict_slashes` + Override the `Map` setting for `strict_slashes` only for this rule. If + not specified the `Map` setting is used. + + `merge_slashes` + Override :attr:`Map.merge_slashes` for this rule. + + `build_only` + Set this to True and the rule will never match but will create a URL + that can be build. This is useful if you have resources on a subdomain + or folder that are not handled by the WSGI application (like static data) + + `redirect_to` + If given this must be either a string or callable. In case of a + callable it's called with the url adapter that triggered the match and + the values of the URL as keyword arguments and has to return the target + for the redirect, otherwise it has to be a string with placeholders in + rule syntax:: + + def foo_with_slug(adapter, id): + # ask the database for the slug for the old id. this of + # course has nothing to do with werkzeug. + return f'foo/{Foo.get_slug_for_id(id)}' + + url_map = Map([ + Rule('/foo/', endpoint='foo'), + Rule('/some/old/url/', redirect_to='foo/'), + Rule('/other/old/url/', redirect_to=foo_with_slug) + ]) + + When the rule is matched the routing system will raise a + `RequestRedirect` exception with the target for the redirect. + + Keep in mind that the URL will be joined against the URL root of the + script so don't use a leading slash on the target URL unless you + really mean root of that domain. + + `alias` + If enabled this rule serves as an alias for another rule with the same + endpoint and arguments. + + `host` + If provided and the URL map has host matching enabled this can be + used to provide a match rule for the whole host. This also means + that the subdomain feature is disabled. + + `websocket` + If ``True``, this rule is only matches for WebSocket (``ws://``, + ``wss://``) requests. By default, rules will only match for HTTP + requests. + + .. versionadded:: 1.0 + Added ``websocket``. + + .. versionadded:: 1.0 + Added ``merge_slashes``. + + .. versionadded:: 0.7 + Added ``alias`` and ``host``. + + .. versionchanged:: 0.6.1 + ``HEAD`` is added to ``methods`` if ``GET`` is present. + """ + + def __init__( + self, + string: str, + defaults: t.Optional[t.Mapping[str, t.Any]] = None, + subdomain: t.Optional[str] = None, + methods: t.Optional[t.Iterable[str]] = None, + build_only: bool = False, + endpoint: t.Optional[str] = None, + strict_slashes: t.Optional[bool] = None, + merge_slashes: t.Optional[bool] = None, + redirect_to: t.Optional[t.Union[str, t.Callable[..., str]]] = None, + alias: bool = False, + host: t.Optional[str] = None, + websocket: bool = False, + ) -> None: + if not string.startswith("/"): + raise ValueError("urls must start with a leading slash") + self.rule = string + self.is_leaf = not string.endswith("/") + + self.map: "Map" = None # type: ignore + self.strict_slashes = strict_slashes + self.merge_slashes = merge_slashes + self.subdomain = subdomain + self.host = host + self.defaults = defaults + self.build_only = build_only + self.alias = alias + self.websocket = websocket + + if methods is not None: + if isinstance(methods, str): + raise TypeError("'methods' should be a list of strings.") + + methods = {x.upper() for x in methods} + + if "HEAD" not in methods and "GET" in methods: + methods.add("HEAD") + + if websocket and methods - {"GET", "HEAD", "OPTIONS"}: + raise ValueError( + "WebSocket rules can only use 'GET', 'HEAD', and 'OPTIONS' methods." + ) + + self.methods = methods + self.endpoint: str = endpoint # type: ignore + self.redirect_to = redirect_to + + if defaults: + self.arguments = set(map(str, defaults)) + else: + self.arguments = set() + + self._trace: t.List[t.Tuple[bool, str]] = [] + + def empty(self) -> "Rule": + """ + Return an unbound copy of this rule. + + This can be useful if want to reuse an already bound URL for another + map. See ``get_empty_kwargs`` to override what keyword arguments are + provided to the new copy. + """ + return type(self)(self.rule, **self.get_empty_kwargs()) + + def get_empty_kwargs(self) -> t.Mapping[str, t.Any]: + """ + Provides kwargs for instantiating empty copy with empty() + + Use this method to provide custom keyword arguments to the subclass of + ``Rule`` when calling ``some_rule.empty()``. Helpful when the subclass + has custom keyword arguments that are needed at instantiation. + + Must return a ``dict`` that will be provided as kwargs to the new + instance of ``Rule``, following the initial ``self.rule`` value which + is always provided as the first, required positional argument. + """ + defaults = None + if self.defaults: + defaults = dict(self.defaults) + return dict( + defaults=defaults, + subdomain=self.subdomain, + methods=self.methods, + build_only=self.build_only, + endpoint=self.endpoint, + strict_slashes=self.strict_slashes, + redirect_to=self.redirect_to, + alias=self.alias, + host=self.host, + ) + + def get_rules(self, map: "Map") -> t.Iterator["Rule"]: + yield self + + def refresh(self) -> None: + """Rebinds and refreshes the URL. Call this if you modified the + rule in place. + + :internal: + """ + self.bind(self.map, rebind=True) + + def bind(self, map: "Map", rebind: bool = False) -> None: + """Bind the url to a map and create a regular expression based on + the information from the rule itself and the defaults from the map. + + :internal: + """ + if self.map is not None and not rebind: + raise RuntimeError(f"url rule {self!r} already bound to map {self.map!r}") + self.map = map + if self.strict_slashes is None: + self.strict_slashes = map.strict_slashes + if self.merge_slashes is None: + self.merge_slashes = map.merge_slashes + if self.subdomain is None: + self.subdomain = map.default_subdomain + self.compile() + + def get_converter( + self, + variable_name: str, + converter_name: str, + args: t.Tuple, + kwargs: t.Mapping[str, t.Any], + ) -> "BaseConverter": + """Looks up the converter for the given parameter. + + .. versionadded:: 0.9 + """ + if converter_name not in self.map.converters: + raise LookupError(f"the converter {converter_name!r} does not exist") + return self.map.converters[converter_name](self.map, *args, **kwargs) + + def _encode_query_vars(self, query_vars: t.Mapping[str, t.Any]) -> str: + return url_encode( + query_vars, + charset=self.map.charset, + sort=self.map.sort_parameters, + key=self.map.sort_key, + ) + + def compile(self) -> None: + """Compiles the regular expression and stores it.""" + assert self.map is not None, "rule not bound" + + if self.map.host_matching: + domain_rule = self.host or "" + else: + domain_rule = self.subdomain or "" + + self._trace = [] + self._converters: t.Dict[str, "BaseConverter"] = {} + self._static_weights: t.List[t.Tuple[int, int]] = [] + self._argument_weights: t.List[int] = [] + regex_parts = [] + + def _build_regex(rule: str) -> None: + index = 0 + for converter, arguments, variable in parse_rule(rule): + if converter is None: + for match in re.finditer(r"/+|[^/]+", variable): + part = match.group(0) + if part.startswith("/"): + if self.merge_slashes: + regex_parts.append(r"/+?") + self._trace.append((False, "/")) + else: + regex_parts.append(part) + self._trace.append((False, part)) + continue + self._trace.append((False, part)) + regex_parts.append(re.escape(part)) + if part: + self._static_weights.append((index, -len(part))) + else: + if arguments: + c_args, c_kwargs = parse_converter_args(arguments) + else: + c_args = () + c_kwargs = {} + convobj = self.get_converter(variable, converter, c_args, c_kwargs) + regex_parts.append(f"(?P<{variable}>{convobj.regex})") + self._converters[variable] = convobj + self._trace.append((True, variable)) + self._argument_weights.append(convobj.weight) + self.arguments.add(str(variable)) + index = index + 1 + + _build_regex(domain_rule) + regex_parts.append("\\|") + self._trace.append((False, "|")) + _build_regex(self.rule if self.is_leaf else self.rule.rstrip("/")) + if not self.is_leaf: + self._trace.append((False, "/")) + + self._build: t.Callable[..., t.Tuple[str, str]] + self._build = self._compile_builder(False).__get__(self, None) # type: ignore + self._build_unknown: t.Callable[..., t.Tuple[str, str]] + self._build_unknown = self._compile_builder(True).__get__( # type: ignore + self, None + ) + + if self.build_only: + return + + if not (self.is_leaf and self.strict_slashes): + reps = "*" if self.merge_slashes else "?" + tail = f"(?/{reps})" + else: + tail = "" + + regex = f"^{''.join(regex_parts)}{tail}$" + self._regex = re.compile(regex) + + def match( + self, path: str, method: t.Optional[str] = None + ) -> t.Optional[t.MutableMapping[str, t.Any]]: + """Check if the rule matches a given path. Path is a string in the + form ``"subdomain|/path"`` and is assembled by the map. If + the map is doing host matching the subdomain part will be the host + instead. + + If the rule matches a dict with the converted values is returned, + otherwise the return value is `None`. + + :internal: + """ + if not self.build_only: + require_redirect = False + + m = self._regex.search(path) + if m is not None: + groups = m.groupdict() + # we have a folder like part of the url without a trailing + # slash and strict slashes enabled. raise an exception that + # tells the map to redirect to the same url but with a + # trailing slash + if ( + self.strict_slashes + and not self.is_leaf + and not groups.pop("__suffix__") + and ( + method is None or self.methods is None or method in self.methods + ) + ): + path += "/" + require_redirect = True + # if we are not in strict slashes mode we have to remove + # a __suffix__ + elif not self.strict_slashes: + del groups["__suffix__"] + + result = {} + for name, value in groups.items(): + try: + value = self._converters[name].to_python(value) + except ValidationError: + return None + result[str(name)] = value + if self.defaults: + result.update(self.defaults) + + if self.merge_slashes: + new_path = "|".join(self.build(result, False)) # type: ignore + if path.endswith("/") and not new_path.endswith("/"): + new_path += "/" + if new_path.count("/") < path.count("/"): + # The URL will be encoded when MapAdapter.match + # handles the RequestPath raised below. Decode + # the URL here to avoid a double encoding. + path = url_unquote(new_path) + require_redirect = True + + if require_redirect: + path = path.split("|", 1)[1] + raise RequestPath(path) + + if self.alias and self.map.redirect_defaults: + raise RequestAliasRedirect(result) + + return result + + return None + + @staticmethod + def _get_func_code(code: CodeType, name: str) -> t.Callable[..., t.Tuple[str, str]]: + globs: t.Dict[str, t.Any] = {} + locs: t.Dict[str, t.Any] = {} + exec(code, globs, locs) + return locs[name] # type: ignore + + def _compile_builder( + self, append_unknown: bool = True + ) -> t.Callable[..., t.Tuple[str, str]]: + defaults = self.defaults or {} + dom_ops: t.List[t.Tuple[bool, str]] = [] + url_ops: t.List[t.Tuple[bool, str]] = [] + + opl = dom_ops + for is_dynamic, data in self._trace: + if data == "|" and opl is dom_ops: + opl = url_ops + continue + # this seems like a silly case to ever come up but: + # if a default is given for a value that appears in the rule, + # resolve it to a constant ahead of time + if is_dynamic and data in defaults: + data = self._converters[data].to_url(defaults[data]) + opl.append((False, data)) + elif not is_dynamic: + opl.append( + (False, url_quote(_to_bytes(data, self.map.charset), safe="/:|+")) + ) + else: + opl.append((True, data)) + + def _convert(elem: str) -> ast.stmt: + ret = _prefix_names(_CALL_CONVERTER_CODE_FMT.format(elem=elem)) + ret.args = [ast.Name(str(elem), ast.Load())] # type: ignore # str for py2 + return ret + + def _parts(ops: t.List[t.Tuple[bool, str]]) -> t.List[ast.AST]: + parts = [ + _convert(elem) if is_dynamic else ast.Str(s=elem) + for is_dynamic, elem in ops + ] + parts = parts or [ast.Str("")] + # constant fold + ret = [parts[0]] + for p in parts[1:]: + if isinstance(p, ast.Str) and isinstance(ret[-1], ast.Str): + ret[-1] = ast.Str(ret[-1].s + p.s) + else: + ret.append(p) + return ret + + dom_parts = _parts(dom_ops) + url_parts = _parts(url_ops) + if not append_unknown: + body = [] + else: + body = [_IF_KWARGS_URL_ENCODE_AST] + url_parts.extend(_URL_ENCODE_AST_NAMES) + + def _join(parts: t.List[ast.AST]) -> ast.AST: + if len(parts) == 1: # shortcut + return parts[0] + return ast.JoinedStr(parts) + + body.append( + ast.Return(ast.Tuple([_join(dom_parts), _join(url_parts)], ast.Load())) + ) + + pargs = [ + elem + for is_dynamic, elem in dom_ops + url_ops + if is_dynamic and elem not in defaults + ] + kargs = [str(k) for k in defaults] + + func_ast: ast.FunctionDef = _prefix_names("def _(): pass") # type: ignore + func_ast.name = f"" + func_ast.args.args.append(ast.arg(".self", None)) + for arg in pargs + kargs: + func_ast.args.args.append(ast.arg(arg, None)) + func_ast.args.kwarg = ast.arg(".kwargs", None) + for _ in kargs: + func_ast.args.defaults.append(ast.Str("")) + func_ast.body = body + + # use `ast.parse` instead of `ast.Module` for better portability + # Python 3.8 changes the signature of `ast.Module` + module = ast.parse("") + module.body = [func_ast] + + # mark everything as on line 1, offset 0 + # less error-prone than `ast.fix_missing_locations` + # bad line numbers cause an assert to fail in debug builds + for node in ast.walk(module): + if "lineno" in node._attributes: + node.lineno = 1 + if "col_offset" in node._attributes: + node.col_offset = 0 + + code = compile(module, "", "exec") + return self._get_func_code(code, func_ast.name) + + def build( + self, values: t.Mapping[str, t.Any], append_unknown: bool = True + ) -> t.Optional[t.Tuple[str, str]]: + """Assembles the relative url for that rule and the subdomain. + If building doesn't work for some reasons `None` is returned. + + :internal: + """ + try: + if append_unknown: + return self._build_unknown(**values) + else: + return self._build(**values) + except ValidationError: + return None + + def provides_defaults_for(self, rule: "Rule") -> bool: + """Check if this rule has defaults for a given rule. + + :internal: + """ + return bool( + not self.build_only + and self.defaults + and self.endpoint == rule.endpoint + and self != rule + and self.arguments == rule.arguments + ) + + def suitable_for( + self, values: t.Mapping[str, t.Any], method: t.Optional[str] = None + ) -> bool: + """Check if the dict of values has enough data for url generation. + + :internal: + """ + # if a method was given explicitly and that method is not supported + # by this rule, this rule is not suitable. + if ( + method is not None + and self.methods is not None + and method not in self.methods + ): + return False + + defaults = self.defaults or () + + # all arguments required must be either in the defaults dict or + # the value dictionary otherwise it's not suitable + for key in self.arguments: + if key not in defaults and key not in values: + return False + + # in case defaults are given we ensure that either the value was + # skipped or the value is the same as the default value. + if defaults: + for key, value in defaults.items(): + if key in values and value != values[key]: + return False + + return True + + def match_compare_key( + self, + ) -> t.Tuple[bool, int, t.Iterable[t.Tuple[int, int]], int, t.Iterable[int]]: + """The match compare key for sorting. + + Current implementation: + + 1. rules without any arguments come first for performance + reasons only as we expect them to match faster and some + common ones usually don't have any arguments (index pages etc.) + 2. rules with more static parts come first so the second argument + is the negative length of the number of the static weights. + 3. we order by static weights, which is a combination of index + and length + 4. The more complex rules come first so the next argument is the + negative length of the number of argument weights. + 5. lastly we order by the actual argument weights. + + :internal: + """ + return ( + bool(self.arguments), + -len(self._static_weights), + self._static_weights, + -len(self._argument_weights), + self._argument_weights, + ) + + def build_compare_key(self) -> t.Tuple[int, int, int]: + """The build compare key for sorting. + + :internal: + """ + return (1 if self.alias else 0, -len(self.arguments), -len(self.defaults or ())) + + def __eq__(self, other: object) -> bool: + return isinstance(other, type(self)) and self._trace == other._trace + + __hash__ = None # type: ignore + + def __str__(self) -> str: + return self.rule + + def __repr__(self) -> str: + if self.map is None: + return f"<{type(self).__name__} (unbound)>" + parts = [] + for is_dynamic, data in self._trace: + if is_dynamic: + parts.append(f"<{data}>") + else: + parts.append(data) + parts = "".join(parts).lstrip("|") + methods = f" ({', '.join(self.methods)})" if self.methods is not None else "" + return f"<{type(self).__name__} {parts!r}{methods} -> {self.endpoint}>" + + +class BaseConverter: + """Base class for all converters.""" + + regex = "[^/]+" + weight = 100 + + def __init__(self, map: "Map", *args: t.Any, **kwargs: t.Any) -> None: + self.map = map + + def to_python(self, value: str) -> t.Any: + return value + + def to_url(self, value: t.Any) -> str: + if isinstance(value, (bytes, bytearray)): + return _fast_url_quote(value) + return _fast_url_quote(str(value).encode(self.map.charset)) + + +class UnicodeConverter(BaseConverter): + """This converter is the default converter and accepts any string but + only one path segment. Thus the string can not include a slash. + + This is the default validator. + + Example:: + + Rule('/pages/'), + Rule('/') + + :param map: the :class:`Map`. + :param minlength: the minimum length of the string. Must be greater + or equal 1. + :param maxlength: the maximum length of the string. + :param length: the exact length of the string. + """ + + def __init__( + self, + map: "Map", + minlength: int = 1, + maxlength: t.Optional[int] = None, + length: t.Optional[int] = None, + ) -> None: + super().__init__(map) + if length is not None: + length_regex = f"{{{int(length)}}}" + else: + if maxlength is None: + maxlength_value = "" + else: + maxlength_value = str(int(maxlength)) + length_regex = f"{{{int(minlength)},{maxlength_value}}}" + self.regex = f"[^/]{length_regex}" + + +class AnyConverter(BaseConverter): + """Matches one of the items provided. Items can either be Python + identifiers or strings:: + + Rule('/') + + :param map: the :class:`Map`. + :param items: this function accepts the possible items as positional + arguments. + """ + + def __init__(self, map: "Map", *items: str) -> None: + super().__init__(map) + self.regex = f"(?:{'|'.join([re.escape(x) for x in items])})" + + +class PathConverter(BaseConverter): + """Like the default :class:`UnicodeConverter`, but it also matches + slashes. This is useful for wikis and similar applications:: + + Rule('/') + Rule('//edit') + + :param map: the :class:`Map`. + """ + + regex = "[^/].*?" + weight = 200 + + +class NumberConverter(BaseConverter): + """Baseclass for `IntegerConverter` and `FloatConverter`. + + :internal: + """ + + weight = 50 + num_convert: t.Callable = int + + def __init__( + self, + map: "Map", + fixed_digits: int = 0, + min: t.Optional[int] = None, + max: t.Optional[int] = None, + signed: bool = False, + ) -> None: + if signed: + self.regex = self.signed_regex + super().__init__(map) + self.fixed_digits = fixed_digits + self.min = min + self.max = max + self.signed = signed + + def to_python(self, value: str) -> t.Any: + if self.fixed_digits and len(value) != self.fixed_digits: + raise ValidationError() + value = self.num_convert(value) + if (self.min is not None and value < self.min) or ( + self.max is not None and value > self.max + ): + raise ValidationError() + return value + + def to_url(self, value: t.Any) -> str: + value = str(self.num_convert(value)) + if self.fixed_digits: + value = value.zfill(self.fixed_digits) + return value + + @property + def signed_regex(self) -> str: + return f"-?{self.regex}" + + +class IntegerConverter(NumberConverter): + """This converter only accepts integer values:: + + Rule("/page/") + + By default it only accepts unsigned, positive values. The ``signed`` + parameter will enable signed, negative values. :: + + Rule("/page/") + + :param map: The :class:`Map`. + :param fixed_digits: The number of fixed digits in the URL. If you + set this to ``4`` for example, the rule will only match if the + URL looks like ``/0001/``. The default is variable length. + :param min: The minimal value. + :param max: The maximal value. + :param signed: Allow signed (negative) values. + + .. versionadded:: 0.15 + The ``signed`` parameter. + """ + + regex = r"\d+" + + +class FloatConverter(NumberConverter): + """This converter only accepts floating point values:: + + Rule("/probability/") + + By default it only accepts unsigned, positive values. The ``signed`` + parameter will enable signed, negative values. :: + + Rule("/offset/") + + :param map: The :class:`Map`. + :param min: The minimal value. + :param max: The maximal value. + :param signed: Allow signed (negative) values. + + .. versionadded:: 0.15 + The ``signed`` parameter. + """ + + regex = r"\d+\.\d+" + num_convert = float + + def __init__( + self, + map: "Map", + min: t.Optional[float] = None, + max: t.Optional[float] = None, + signed: bool = False, + ) -> None: + super().__init__(map, min=min, max=max, signed=signed) # type: ignore + + +class UUIDConverter(BaseConverter): + """This converter only accepts UUID strings:: + + Rule('/object/') + + .. versionadded:: 0.10 + + :param map: the :class:`Map`. + """ + + regex = ( + r"[A-Fa-f0-9]{8}-[A-Fa-f0-9]{4}-" + r"[A-Fa-f0-9]{4}-[A-Fa-f0-9]{4}-[A-Fa-f0-9]{12}" + ) + + def to_python(self, value: str) -> uuid.UUID: + return uuid.UUID(value) + + def to_url(self, value: uuid.UUID) -> str: + return str(value) + + +#: the default converter mapping for the map. +DEFAULT_CONVERTERS: t.Mapping[str, t.Type[BaseConverter]] = { + "default": UnicodeConverter, + "string": UnicodeConverter, + "any": AnyConverter, + "path": PathConverter, + "int": IntegerConverter, + "float": FloatConverter, + "uuid": UUIDConverter, +} + + +class Map: + """The map class stores all the URL rules and some configuration + parameters. Some of the configuration values are only stored on the + `Map` instance since those affect all rules, others are just defaults + and can be overridden for each rule. Note that you have to specify all + arguments besides the `rules` as keyword arguments! + + :param rules: sequence of url rules for this map. + :param default_subdomain: The default subdomain for rules without a + subdomain defined. + :param charset: charset of the url. defaults to ``"utf-8"`` + :param strict_slashes: If a rule ends with a slash but the matched + URL does not, redirect to the URL with a trailing slash. + :param merge_slashes: Merge consecutive slashes when matching or + building URLs. Matches will redirect to the normalized URL. + Slashes in variable parts are not merged. + :param redirect_defaults: This will redirect to the default rule if it + wasn't visited that way. This helps creating + unique URLs. + :param converters: A dict of converters that adds additional converters + to the list of converters. If you redefine one + converter this will override the original one. + :param sort_parameters: If set to `True` the url parameters are sorted. + See `url_encode` for more details. + :param sort_key: The sort key function for `url_encode`. + :param encoding_errors: the error method to use for decoding + :param host_matching: if set to `True` it enables the host matching + feature and disables the subdomain one. If + enabled the `host` parameter to rules is used + instead of the `subdomain` one. + + .. versionchanged:: 1.0 + If ``url_scheme`` is ``ws`` or ``wss``, only WebSocket rules + will match. + + .. versionchanged:: 1.0 + Added ``merge_slashes``. + + .. versionchanged:: 0.7 + Added ``encoding_errors`` and ``host_matching``. + + .. versionchanged:: 0.5 + Added ``sort_parameters`` and ``sort_key``. + """ + + #: A dict of default converters to be used. + default_converters = ImmutableDict(DEFAULT_CONVERTERS) + + #: The type of lock to use when updating. + #: + #: .. versionadded:: 1.0 + lock_class = Lock + + def __init__( + self, + rules: t.Optional[t.Iterable[RuleFactory]] = None, + default_subdomain: str = "", + charset: str = "utf-8", + strict_slashes: bool = True, + merge_slashes: bool = True, + redirect_defaults: bool = True, + converters: t.Optional[t.Mapping[str, t.Type[BaseConverter]]] = None, + sort_parameters: bool = False, + sort_key: t.Optional[t.Callable[[t.Any], t.Any]] = None, + encoding_errors: str = "replace", + host_matching: bool = False, + ) -> None: + self._rules: t.List[Rule] = [] + self._rules_by_endpoint: t.Dict[str, t.List[Rule]] = {} + self._remap = True + self._remap_lock = self.lock_class() + + self.default_subdomain = default_subdomain + self.charset = charset + self.encoding_errors = encoding_errors + self.strict_slashes = strict_slashes + self.merge_slashes = merge_slashes + self.redirect_defaults = redirect_defaults + self.host_matching = host_matching + + self.converters = self.default_converters.copy() + if converters: + self.converters.update(converters) + + self.sort_parameters = sort_parameters + self.sort_key = sort_key + + for rulefactory in rules or (): + self.add(rulefactory) + + def is_endpoint_expecting(self, endpoint: str, *arguments: str) -> bool: + """Iterate over all rules and check if the endpoint expects + the arguments provided. This is for example useful if you have + some URLs that expect a language code and others that do not and + you want to wrap the builder a bit so that the current language + code is automatically added if not provided but endpoints expect + it. + + :param endpoint: the endpoint to check. + :param arguments: this function accepts one or more arguments + as positional arguments. Each one of them is + checked. + """ + self.update() + arguments = set(arguments) + for rule in self._rules_by_endpoint[endpoint]: + if arguments.issubset(rule.arguments): + return True + return False + + def iter_rules(self, endpoint: t.Optional[str] = None) -> t.Iterator[Rule]: + """Iterate over all rules or the rules of an endpoint. + + :param endpoint: if provided only the rules for that endpoint + are returned. + :return: an iterator + """ + self.update() + if endpoint is not None: + return iter(self._rules_by_endpoint[endpoint]) + return iter(self._rules) + + def add(self, rulefactory: RuleFactory) -> None: + """Add a new rule or factory to the map and bind it. Requires that the + rule is not bound to another map. + + :param rulefactory: a :class:`Rule` or :class:`RuleFactory` + """ + for rule in rulefactory.get_rules(self): + rule.bind(self) + self._rules.append(rule) + self._rules_by_endpoint.setdefault(rule.endpoint, []).append(rule) + self._remap = True + + def bind( + self, + server_name: str, + script_name: t.Optional[str] = None, + subdomain: t.Optional[str] = None, + url_scheme: str = "http", + default_method: str = "GET", + path_info: t.Optional[str] = None, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + ) -> "MapAdapter": + """Return a new :class:`MapAdapter` with the details specified to the + call. Note that `script_name` will default to ``'/'`` if not further + specified or `None`. The `server_name` at least is a requirement + because the HTTP RFC requires absolute URLs for redirects and so all + redirect exceptions raised by Werkzeug will contain the full canonical + URL. + + If no path_info is passed to :meth:`match` it will use the default path + info passed to bind. While this doesn't really make sense for + manual bind calls, it's useful if you bind a map to a WSGI + environment which already contains the path info. + + `subdomain` will default to the `default_subdomain` for this map if + no defined. If there is no `default_subdomain` you cannot use the + subdomain feature. + + .. versionchanged:: 1.0 + If ``url_scheme`` is ``ws`` or ``wss``, only WebSocket rules + will match. + + .. versionchanged:: 0.15 + ``path_info`` defaults to ``'/'`` if ``None``. + + .. versionchanged:: 0.8 + ``query_args`` can be a string. + + .. versionchanged:: 0.7 + Added ``query_args``. + """ + server_name = server_name.lower() + if self.host_matching: + if subdomain is not None: + raise RuntimeError("host matching enabled and a subdomain was provided") + elif subdomain is None: + subdomain = self.default_subdomain + if script_name is None: + script_name = "/" + if path_info is None: + path_info = "/" + + try: + server_name = _encode_idna(server_name) # type: ignore + except UnicodeError as e: + raise BadHost() from e + + return MapAdapter( + self, + server_name, + script_name, + subdomain, + url_scheme, + path_info, + default_method, + query_args, + ) + + def bind_to_environ( + self, + environ: "WSGIEnvironment", + server_name: t.Optional[str] = None, + subdomain: t.Optional[str] = None, + ) -> "MapAdapter": + """Like :meth:`bind` but you can pass it an WSGI environment and it + will fetch the information from that dictionary. Note that because of + limitations in the protocol there is no way to get the current + subdomain and real `server_name` from the environment. If you don't + provide it, Werkzeug will use `SERVER_NAME` and `SERVER_PORT` (or + `HTTP_HOST` if provided) as used `server_name` with disabled subdomain + feature. + + If `subdomain` is `None` but an environment and a server name is + provided it will calculate the current subdomain automatically. + Example: `server_name` is ``'example.com'`` and the `SERVER_NAME` + in the wsgi `environ` is ``'staging.dev.example.com'`` the calculated + subdomain will be ``'staging.dev'``. + + If the object passed as environ has an environ attribute, the value of + this attribute is used instead. This allows you to pass request + objects. Additionally `PATH_INFO` added as a default of the + :class:`MapAdapter` so that you don't have to pass the path info to + the match method. + + .. versionchanged:: 1.0.0 + If the passed server name specifies port 443, it will match + if the incoming scheme is ``https`` without a port. + + .. versionchanged:: 1.0.0 + A warning is shown when the passed server name does not + match the incoming WSGI server name. + + .. versionchanged:: 0.8 + This will no longer raise a ValueError when an unexpected server + name was passed. + + .. versionchanged:: 0.5 + previously this method accepted a bogus `calculate_subdomain` + parameter that did not have any effect. It was removed because + of that. + + :param environ: a WSGI environment. + :param server_name: an optional server name hint (see above). + :param subdomain: optionally the current subdomain (see above). + """ + environ = _get_environ(environ) + wsgi_server_name = get_host(environ).lower() + scheme = environ["wsgi.url_scheme"] + upgrade = any( + v.strip() == "upgrade" + for v in environ.get("HTTP_CONNECTION", "").lower().split(",") + ) + + if upgrade and environ.get("HTTP_UPGRADE", "").lower() == "websocket": + scheme = "wss" if scheme == "https" else "ws" + + if server_name is None: + server_name = wsgi_server_name + else: + server_name = server_name.lower() + + # strip standard port to match get_host() + if scheme in {"http", "ws"} and server_name.endswith(":80"): + server_name = server_name[:-3] + elif scheme in {"https", "wss"} and server_name.endswith(":443"): + server_name = server_name[:-4] + + if subdomain is None and not self.host_matching: + cur_server_name = wsgi_server_name.split(".") + real_server_name = server_name.split(".") + offset = -len(real_server_name) + + if cur_server_name[offset:] != real_server_name: + # This can happen even with valid configs if the server was + # accessed directly by IP address under some situations. + # Instead of raising an exception like in Werkzeug 0.7 or + # earlier we go by an invalid subdomain which will result + # in a 404 error on matching. + warnings.warn( + f"Current server name {wsgi_server_name!r} doesn't match configured" + f" server name {server_name!r}", + stacklevel=2, + ) + subdomain = "" + else: + subdomain = ".".join(filter(None, cur_server_name[:offset])) + + def _get_wsgi_string(name: str) -> t.Optional[str]: + val = environ.get(name) + if val is not None: + return _wsgi_decoding_dance(val, self.charset) + return None + + script_name = _get_wsgi_string("SCRIPT_NAME") + path_info = _get_wsgi_string("PATH_INFO") + query_args = _get_wsgi_string("QUERY_STRING") + return Map.bind( + self, + server_name, + script_name, + subdomain, + scheme, + environ["REQUEST_METHOD"], + path_info, + query_args=query_args, + ) + + def update(self) -> None: + """Called before matching and building to keep the compiled rules + in the correct order after things changed. + """ + if not self._remap: + return + + with self._remap_lock: + if not self._remap: + return + + self._rules.sort(key=lambda x: x.match_compare_key()) + for rules in self._rules_by_endpoint.values(): + rules.sort(key=lambda x: x.build_compare_key()) + self._remap = False + + def __repr__(self) -> str: + rules = self.iter_rules() + return f"{type(self).__name__}({pformat(list(rules))})" + + +class MapAdapter: + + """Returned by :meth:`Map.bind` or :meth:`Map.bind_to_environ` and does + the URL matching and building based on runtime information. + """ + + def __init__( + self, + map: Map, + server_name: str, + script_name: str, + subdomain: t.Optional[str], + url_scheme: str, + path_info: str, + default_method: str, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + ): + self.map = map + self.server_name = _to_str(server_name) + script_name = _to_str(script_name) + if not script_name.endswith("/"): + script_name += "/" + self.script_name = script_name + self.subdomain = _to_str(subdomain) + self.url_scheme = _to_str(url_scheme) + self.path_info = _to_str(path_info) + self.default_method = _to_str(default_method) + self.query_args = query_args + self.websocket = self.url_scheme in {"ws", "wss"} + + def dispatch( + self, + view_func: t.Callable[[str, t.Mapping[str, t.Any]], "WSGIApplication"], + path_info: t.Optional[str] = None, + method: t.Optional[str] = None, + catch_http_exceptions: bool = False, + ) -> "WSGIApplication": + """Does the complete dispatching process. `view_func` is called with + the endpoint and a dict with the values for the view. It should + look up the view function, call it, and return a response object + or WSGI application. http exceptions are not caught by default + so that applications can display nicer error messages by just + catching them by hand. If you want to stick with the default + error messages you can pass it ``catch_http_exceptions=True`` and + it will catch the http exceptions. + + Here a small example for the dispatch usage:: + + from werkzeug.wrappers import Request, Response + from werkzeug.wsgi import responder + from werkzeug.routing import Map, Rule + + def on_index(request): + return Response('Hello from the index') + + url_map = Map([Rule('/', endpoint='index')]) + views = {'index': on_index} + + @responder + def application(environ, start_response): + request = Request(environ) + urls = url_map.bind_to_environ(environ) + return urls.dispatch(lambda e, v: views[e](request, **v), + catch_http_exceptions=True) + + Keep in mind that this method might return exception objects, too, so + use :class:`Response.force_type` to get a response object. + + :param view_func: a function that is called with the endpoint as + first argument and the value dict as second. Has + to dispatch to the actual view function with this + information. (see above) + :param path_info: the path info to use for matching. Overrides the + path info specified on binding. + :param method: the HTTP method used for matching. Overrides the + method specified on binding. + :param catch_http_exceptions: set to `True` to catch any of the + werkzeug :class:`HTTPException`\\s. + """ + try: + try: + endpoint, args = self.match(path_info, method) + except RequestRedirect as e: + return e + return view_func(endpoint, args) + except HTTPException as e: + if catch_http_exceptions: + return e + raise + + @typing.overload + def match( # type: ignore + self, + path_info: t.Optional[str] = None, + method: t.Optional[str] = None, + return_rule: "te.Literal[False]" = False, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + websocket: t.Optional[bool] = None, + ) -> t.Tuple[str, t.Mapping[str, t.Any]]: + ... + + @typing.overload + def match( + self, + path_info: t.Optional[str] = None, + method: t.Optional[str] = None, + return_rule: "te.Literal[True]" = True, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + websocket: t.Optional[bool] = None, + ) -> t.Tuple[Rule, t.Mapping[str, t.Any]]: + ... + + def match( + self, + path_info: t.Optional[str] = None, + method: t.Optional[str] = None, + return_rule: bool = False, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + websocket: t.Optional[bool] = None, + ) -> t.Tuple[t.Union[str, Rule], t.Mapping[str, t.Any]]: + """The usage is simple: you just pass the match method the current + path info as well as the method (which defaults to `GET`). The + following things can then happen: + + - you receive a `NotFound` exception that indicates that no URL is + matching. A `NotFound` exception is also a WSGI application you + can call to get a default page not found page (happens to be the + same object as `werkzeug.exceptions.NotFound`) + + - you receive a `MethodNotAllowed` exception that indicates that there + is a match for this URL but not for the current request method. + This is useful for RESTful applications. + + - you receive a `RequestRedirect` exception with a `new_url` + attribute. This exception is used to notify you about a request + Werkzeug requests from your WSGI application. This is for example the + case if you request ``/foo`` although the correct URL is ``/foo/`` + You can use the `RequestRedirect` instance as response-like object + similar to all other subclasses of `HTTPException`. + + - you receive a ``WebsocketMismatch`` exception if the only + match is a WebSocket rule but the bind is an HTTP request, or + if the match is an HTTP rule but the bind is a WebSocket + request. + + - you get a tuple in the form ``(endpoint, arguments)`` if there is + a match (unless `return_rule` is True, in which case you get a tuple + in the form ``(rule, arguments)``) + + If the path info is not passed to the match method the default path + info of the map is used (defaults to the root URL if not defined + explicitly). + + All of the exceptions raised are subclasses of `HTTPException` so they + can be used as WSGI responses. They will all render generic error or + redirect pages. + + Here is a small example for matching: + + >>> m = Map([ + ... Rule('/', endpoint='index'), + ... Rule('/downloads/', endpoint='downloads/index'), + ... Rule('/downloads/', endpoint='downloads/show') + ... ]) + >>> urls = m.bind("example.com", "/") + >>> urls.match("/", "GET") + ('index', {}) + >>> urls.match("/downloads/42") + ('downloads/show', {'id': 42}) + + And here is what happens on redirect and missing URLs: + + >>> urls.match("/downloads") + Traceback (most recent call last): + ... + RequestRedirect: http://example.com/downloads/ + >>> urls.match("/missing") + Traceback (most recent call last): + ... + NotFound: 404 Not Found + + :param path_info: the path info to use for matching. Overrides the + path info specified on binding. + :param method: the HTTP method used for matching. Overrides the + method specified on binding. + :param return_rule: return the rule that matched instead of just the + endpoint (defaults to `False`). + :param query_args: optional query arguments that are used for + automatic redirects as string or dictionary. It's + currently not possible to use the query arguments + for URL matching. + :param websocket: Match WebSocket instead of HTTP requests. A + websocket request has a ``ws`` or ``wss`` + :attr:`url_scheme`. This overrides that detection. + + .. versionadded:: 1.0 + Added ``websocket``. + + .. versionchanged:: 0.8 + ``query_args`` can be a string. + + .. versionadded:: 0.7 + Added ``query_args``. + + .. versionadded:: 0.6 + Added ``return_rule``. + """ + self.map.update() + if path_info is None: + path_info = self.path_info + else: + path_info = _to_str(path_info, self.map.charset) + if query_args is None: + query_args = self.query_args or {} + method = (method or self.default_method).upper() + + if websocket is None: + websocket = self.websocket + + require_redirect = False + + domain_part = self.server_name if self.map.host_matching else self.subdomain + path_part = f"/{path_info.lstrip('/')}" if path_info else "" + path = f"{domain_part}|{path_part}" + + have_match_for = set() + websocket_mismatch = False + + for rule in self.map._rules: + try: + rv = rule.match(path, method) + except RequestPath as e: + raise RequestRedirect( + self.make_redirect_url( + url_quote(e.path_info, self.map.charset, safe="/:|+"), + query_args, + ) + ) from None + except RequestAliasRedirect as e: + raise RequestRedirect( + self.make_alias_redirect_url( + path, rule.endpoint, e.matched_values, method, query_args + ) + ) from None + if rv is None: + continue + if rule.methods is not None and method not in rule.methods: + have_match_for.update(rule.methods) + continue + + if rule.websocket != websocket: + websocket_mismatch = True + continue + + if self.map.redirect_defaults: + redirect_url = self.get_default_redirect(rule, method, rv, query_args) + if redirect_url is not None: + raise RequestRedirect(redirect_url) + + if rule.redirect_to is not None: + if isinstance(rule.redirect_to, str): + + def _handle_match(match: t.Match[str]) -> str: + value = rv[match.group(1)] # type: ignore + return rule._converters[match.group(1)].to_url(value) + + redirect_url = _simple_rule_re.sub(_handle_match, rule.redirect_to) + else: + redirect_url = rule.redirect_to(self, **rv) + + if self.subdomain: + netloc = f"{self.subdomain}.{self.server_name}" + else: + netloc = self.server_name + + raise RequestRedirect( + url_join( + f"{self.url_scheme or 'http'}://{netloc}{self.script_name}", + redirect_url, + ) + ) + + if require_redirect: + raise RequestRedirect( + self.make_redirect_url( + url_quote(path_info, self.map.charset, safe="/:|+"), query_args + ) + ) + + if return_rule: + return rule, rv + else: + return rule.endpoint, rv + + if have_match_for: + raise MethodNotAllowed(valid_methods=list(have_match_for)) + + if websocket_mismatch: + raise WebsocketMismatch() + + raise NotFound() + + def test( + self, path_info: t.Optional[str] = None, method: t.Optional[str] = None + ) -> bool: + """Test if a rule would match. Works like `match` but returns `True` + if the URL matches, or `False` if it does not exist. + + :param path_info: the path info to use for matching. Overrides the + path info specified on binding. + :param method: the HTTP method used for matching. Overrides the + method specified on binding. + """ + try: + self.match(path_info, method) + except RequestRedirect: + pass + except HTTPException: + return False + return True + + def allowed_methods(self, path_info: t.Optional[str] = None) -> t.Iterable[str]: + """Returns the valid methods that match for a given path. + + .. versionadded:: 0.7 + """ + try: + self.match(path_info, method="--") + except MethodNotAllowed as e: + return e.valid_methods # type: ignore + except HTTPException: + pass + return [] + + def get_host(self, domain_part: t.Optional[str]) -> str: + """Figures out the full host name for the given domain part. The + domain part is a subdomain in case host matching is disabled or + a full host name. + """ + if self.map.host_matching: + if domain_part is None: + return self.server_name + return _to_str(domain_part, "ascii") + subdomain = domain_part + if subdomain is None: + subdomain = self.subdomain + else: + subdomain = _to_str(subdomain, "ascii") + + if subdomain: + return f"{subdomain}.{self.server_name}" + else: + return self.server_name + + def get_default_redirect( + self, + rule: Rule, + method: str, + values: t.MutableMapping[str, t.Any], + query_args: t.Union[t.Mapping[str, t.Any], str], + ) -> t.Optional[str]: + """A helper that returns the URL to redirect to if it finds one. + This is used for default redirecting only. + + :internal: + """ + assert self.map.redirect_defaults + for r in self.map._rules_by_endpoint[rule.endpoint]: + # every rule that comes after this one, including ourself + # has a lower priority for the defaults. We order the ones + # with the highest priority up for building. + if r is rule: + break + if r.provides_defaults_for(rule) and r.suitable_for(values, method): + values.update(r.defaults) # type: ignore + domain_part, path = r.build(values) # type: ignore + return self.make_redirect_url(path, query_args, domain_part=domain_part) + return None + + def encode_query_args(self, query_args: t.Union[t.Mapping[str, t.Any], str]) -> str: + if not isinstance(query_args, str): + return url_encode(query_args, self.map.charset) + return query_args + + def make_redirect_url( + self, + path_info: str, + query_args: t.Optional[t.Union[t.Mapping[str, t.Any], str]] = None, + domain_part: t.Optional[str] = None, + ) -> str: + """Creates a redirect URL. + + :internal: + """ + if query_args: + suffix = f"?{self.encode_query_args(query_args)}" + else: + suffix = "" + + scheme = self.url_scheme or "http" + host = self.get_host(domain_part) + path = posixpath.join(self.script_name.strip("/"), path_info.lstrip("/")) + return f"{scheme}://{host}/{path}{suffix}" + + def make_alias_redirect_url( + self, + path: str, + endpoint: str, + values: t.Mapping[str, t.Any], + method: str, + query_args: t.Union[t.Mapping[str, t.Any], str], + ) -> str: + """Internally called to make an alias redirect URL.""" + url = self.build( + endpoint, values, method, append_unknown=False, force_external=True + ) + if query_args: + url += f"?{self.encode_query_args(query_args)}" + assert url != path, "detected invalid alias setting. No canonical URL found" + return url + + def _partial_build( + self, + endpoint: str, + values: t.Mapping[str, t.Any], + method: t.Optional[str], + append_unknown: bool, + ) -> t.Optional[t.Tuple[str, str, bool]]: + """Helper for :meth:`build`. Returns subdomain and path for the + rule that accepts this endpoint, values and method. + + :internal: + """ + # in case the method is none, try with the default method first + if method is None: + rv = self._partial_build( + endpoint, values, self.default_method, append_unknown + ) + if rv is not None: + return rv + + # Default method did not match or a specific method is passed. + # Check all for first match with matching host. If no matching + # host is found, go with first result. + first_match = None + + for rule in self.map._rules_by_endpoint.get(endpoint, ()): + if rule.suitable_for(values, method): + build_rv = rule.build(values, append_unknown) + + if build_rv is not None: + rv = (build_rv[0], build_rv[1], rule.websocket) + if self.map.host_matching: + if rv[0] == self.server_name: + return rv + elif first_match is None: + first_match = rv + else: + return rv + + return first_match + + def build( + self, + endpoint: str, + values: t.Optional[t.Mapping[str, t.Any]] = None, + method: t.Optional[str] = None, + force_external: bool = False, + append_unknown: bool = True, + url_scheme: t.Optional[str] = None, + ) -> str: + """Building URLs works pretty much the other way round. Instead of + `match` you call `build` and pass it the endpoint and a dict of + arguments for the placeholders. + + The `build` function also accepts an argument called `force_external` + which, if you set it to `True` will force external URLs. Per default + external URLs (include the server name) will only be used if the + target URL is on a different subdomain. + + >>> m = Map([ + ... Rule('/', endpoint='index'), + ... Rule('/downloads/', endpoint='downloads/index'), + ... Rule('/downloads/', endpoint='downloads/show') + ... ]) + >>> urls = m.bind("example.com", "/") + >>> urls.build("index", {}) + '/' + >>> urls.build("downloads/show", {'id': 42}) + '/downloads/42' + >>> urls.build("downloads/show", {'id': 42}, force_external=True) + 'http://example.com/downloads/42' + + Because URLs cannot contain non ASCII data you will always get + bytes back. Non ASCII characters are urlencoded with the + charset defined on the map instance. + + Additional values are converted to strings and appended to the URL as + URL querystring parameters: + + >>> urls.build("index", {'q': 'My Searchstring'}) + '/?q=My+Searchstring' + + When processing those additional values, lists are furthermore + interpreted as multiple values (as per + :py:class:`werkzeug.datastructures.MultiDict`): + + >>> urls.build("index", {'q': ['a', 'b', 'c']}) + '/?q=a&q=b&q=c' + + Passing a ``MultiDict`` will also add multiple values: + + >>> urls.build("index", MultiDict((('p', 'z'), ('q', 'a'), ('q', 'b')))) + '/?p=z&q=a&q=b' + + If a rule does not exist when building a `BuildError` exception is + raised. + + The build method accepts an argument called `method` which allows you + to specify the method you want to have an URL built for if you have + different methods for the same endpoint specified. + + :param endpoint: the endpoint of the URL to build. + :param values: the values for the URL to build. Unhandled values are + appended to the URL as query parameters. + :param method: the HTTP method for the rule if there are different + URLs for different methods on the same endpoint. + :param force_external: enforce full canonical external URLs. If the URL + scheme is not provided, this will generate + a protocol-relative URL. + :param append_unknown: unknown parameters are appended to the generated + URL as query string argument. Disable this + if you want the builder to ignore those. + :param url_scheme: Scheme to use in place of the bound + :attr:`url_scheme`. + + .. versionchanged:: 2.0 + Added the ``url_scheme`` parameter. + + .. versionadded:: 0.6 + Added the ``append_unknown`` parameter. + """ + self.map.update() + + if values: + temp_values: t.Dict[str, t.Union[t.List[t.Any], t.Any]] = {} + always_list = isinstance(values, MultiDict) + key: str + value: t.Optional[t.Union[t.List[t.Any], t.Any]] + + # For MultiDict, dict.items(values) is like values.lists() + # without the call or list coercion overhead. + for key, value in dict.items(values): # type: ignore + if value is None: + continue + + if always_list or isinstance(value, (list, tuple)): + value = [v for v in value if v is not None] + + if not value: + continue + + if len(value) == 1: + value = value[0] + + temp_values[key] = value + + values = temp_values + else: + values = {} + + rv = self._partial_build(endpoint, values, method, append_unknown) + if rv is None: + raise BuildError(endpoint, values, method, self) + + domain_part, path, websocket = rv + host = self.get_host(domain_part) + + if url_scheme is None: + url_scheme = self.url_scheme + + # Always build WebSocket routes with the scheme (browsers + # require full URLs). If bound to a WebSocket, ensure that HTTP + # routes are built with an HTTP scheme. + secure = url_scheme in {"https", "wss"} + + if websocket: + force_external = True + url_scheme = "wss" if secure else "ws" + elif url_scheme: + url_scheme = "https" if secure else "http" + + # shortcut this. + if not force_external and ( + (self.map.host_matching and host == self.server_name) + or (not self.map.host_matching and domain_part == self.subdomain) + ): + return f"{self.script_name.rstrip('/')}/{path.lstrip('/')}" + + scheme = f"{url_scheme}:" if url_scheme else "" + return f"{scheme}//{host}{self.script_name[:-1]}/{path.lstrip('/')}" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..43a25aea344388151457d89b1595495a4166fc8f GIT binary patch literal 156 zcmYe~<>g`kf}g*t5<&E15P=LBfgA@QE@lA|DGb33nv8xc8Hzx{2;!Gxid9T{PHB2h zYD__8S!!OHv7Tj&Pi9g~ab`)XZb4#lc4B&JaZGt?QFc{oX}W%KVqS4(zJ7dsW?p7V Ze7s&kfXD8K0g@qtRin*K2$4*(-@4-f)Bf&b614Eb(fWjTZ{xFpSl0TUu$P^o%xZ z*SIL+@Rn5VdqS1{m}lO2=8u4RrJyRjQbj?E5Pn~eWXZ<{r0SlpyTAVC>+kLfN+nmr z?_XbR1}|LHv_I2e{AXcs4K3PXn#MKG+FG5SdYg6hy3PnT+D6B$n+i4oTXjppR@?66 z>Ny45fStOd;2hw5J+EK~uv>Ql=egT1bc*$&f(w94^^$^%?Q&O;`j}z%IG@Jsw3yyDwpsne*vbh$gO!=V%FNix zET6;5++byPY~>_Bg_To-mASE%)BFrp&J0#g;>~CIIn11+nffVlYFn$H#_W0SVb&8C zX3y{o^|M0TIma&wt#y7^uX{8Sm{X$*YVDFZJEIL|E`q{kegzb+;GCB*dWJuX(X$v` z=IkA<^4#a7yIO^%c^KYyY#Gv{SG}FK@`(-v8kTU-Co@6hCv&1)>6OM z7N6^&gHhg(yZ*{XEQm~w22m^td`kpeNSZxyU%b~BQCtn&F*yE%S!D)R1R%6J<62!;htX53`bdOv?K2~Fd_N32!uM0x_d8wQZxdYf z{rCDoJ6riolhYufx-V|9^x1*p9FEHsl1T9Yc#q77kP6C7jD%mEBDd9y*Buv}=SvgKl_| z2bwU1$=NG#87K%RxhF-?S!s*ZBo);@vn0JlPEmIpU1}+LrxU&(gkd)hNHvk~k4~3C zCuqYgIsz1ruCB&UXY3p>4>Kk#FsOq;0}Ps}^+r>)d1{hW(_E&tsP>tCkWB-YAWst$ zq`4!xJA;K&XpxD|)geQgc{+d3VD$+8NPyr^@o9ih6MR~!`9`xXW-A9pCP@}bWU0B*?Y56( z@e**JMH|VCW}eRA*Be{4*KBv!`a&^RlP8IRJuk^1Wk)3Wd3r0^I_!wXhu-;huIki; z;3S5coW$NEUqZ+F4%*P6X#Dh-d;_aPV-N-csHu8O^|tDBs&|Ib;vM*ks8#X@EL9qy z1i!mqy?*D$Vl_4IUBADSnzybmT~D3rz1xd--+WL_ott;>+*_ zVfNrJXqR~Yx-~3$$L|)+S#X+wlq6neV3nEX2C9fIAUGLsTyxt8xLE$;N z>bf3&OY6d;(CLx!d(Fs`BJRsjaM~L@3YzTzQP0Efpxy4i@5R7x02GquqTrEGWN2DZ zK$Pv^_3)<+Lg3Bl;qzW|)#D;+O2Mxx>>5SXm2N-ef!s)^JHcarwJSS*w$G26n4sg-cD^1HG-Z<^LHLBF5RYuw9p%*FCUun_`3Kh?rBrWWfP&ohnwu|ccbSoxV2>fah+>%i9cui#5X_eE98u1pOis?_K-!-^qa1yVhS8ZGw2_5f(evG}9J zR?HB@`|V~Z`q&atsi2X#SP^aT)Hlx_64m(5imq}%CNqli!ymyUHzl(l0Z34S^))%E zTtN$8f{bW}$%PnZ-a;jfC);MTaF`Z*Xky;n);?fikydvsat_qzWa@ft30d$(5X~%t z-l1e8OMqZsk7E&XutuWD_&Z=UMJXDh`6x@NzXn!B=|w~0c60~kGV>qZbdEav_`ZEM zLe&bTe|6qlG?2i+DCr4Ja<8WAqyawz%oSuaa zAeW%HKzq0b%;K*08~r3%7Fk#}SE9LBwYZ!Z-1rza_k@Liz$(4heW*WS^2K=K;Cr9w z@>-(pkQMKv49?8GxdCNvCgvk1{}>6wOnRq5~5;H+^`PkTkM&nsE%73hH5ubB(PVh~dR%7t3OPe^^ImyX7 zPR(k&jA!R*gY(n7nyGE&w~(5)3gHSc&Kx=;lfU0DU2w8Z zq-_=Uw2(ib0hgqo7*AOA&!q4~kFLdM6C)|`BAqQ<7@R1tP6U~^&XMfn^BKKumgx-h z&;!pjskc0m#{ied7ZMg<+$M=|=%7RtKhb`xlP(gvot0~!QuoL9-Vp{^Q~za!zTh>dQ@y~?FDU#nJc`BW*%?-4;NcU1n6 zF9S;L2MxU#;F09R~MDEbYt;)?QLIW zocq}NN|!JR|ipq*4rNh*@0hb}eNM6617b(N6cq&agHaW>04RYH7)x=Yll$V0WP zq~bPpn~*8^3mZaG@mVRVz>`|4kV&mh5aTqY6(zs4Fs2e9J&t8Cl6t*BlJgPI*W&eh zo{Kip8^XOL86OPdZiwB!dd){zjwCvbnR=0x5y~bR-9={bEbCOAOYuEj?C=6yY5Xldv6qSG%RX`x-)=v19C_N_}X^IV43S2paEL95w5%j^JZ% zS#VlAF=;-rs9!}8W!iglaSkbzoWsgesP}i`;S07P-@>!vq%&_-uivWP_ix^S(j|~WC7a%(|l?Ny&f4Gg?!|pQIa9=NKM+O^qE@l z2V9c&=N?IQ%Ae3wMX$64$rhoTIktKJkR*cf9?F-etyyo&B^H1)y3VP;K*lj#tTaM1GW z#v@Ip1knyEpIYuL{9+cqgY;w|m9SQEo6Tt7SKfs8IiT|q)=afl8m?hRS2$((2Y6~t zz|)?GCmBfl#?BBs%sPpJ*Jug+BLNbDPn=_pp*tNKl@tlO4mG{xRSfNe=Mn zL{mswOr8Vh$MVDd-T2L)r(i6ixJuT%ii!Cj+&FVF}JBNc$+%N(dVQ2`I5Uic{9sXYXY8& z`-`_(z=hOPcbNsRazZ`;rphe`^Oed%Dzeijs4Rm}^2lt@C5S#HWrmPba!B@-W(rIIkk=6adZ zCSrBJfzJb=N--{V#p8y^J``tH19Lr&ds*^V{L_cdEahJyNM(1WkY{N~Q7|h`en8Oo zsav4#$LQ*%(UlgNL;ivmD0Zrojwx$TD5>*G_Ko>9Rj=Iut^+NM{Z%4RW20<3Y>FB* ZIAsr>=A>yGldcJ!mW?T+{44GBe*y01hi3o) literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/request.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/request.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..8e048ca1353b51c5fc75005fd7a4e267d8790b53 GIT binary patch literal 17152 zcmc&*U2GiJb>5l%*<-JJ#6Pa0WlWd>mQ1>zT~I&_(x878e)r7yP-F$=DfNYh+9f z|MiC6)J*jYQ*$To9kj{EsWzF9B}+%KSCG>hCXqF*vg+%KU&WDaqE2>oGmnES)% zkC-FeA3=ZA9OeEf`eWu8_s7s5H^;d@j{bx>!TkyJC(TLjPolre+{OJ}=ueqb+@C^! zx4E19yBm9&d(FMv--G@>b07EjqQBqV&;5PqA21Jae?R&M&4b)Ofc_!#5cdzFf7m?C z{X^&Ked>X3PTSgIrhNKm zB+YAOEiTzs=!9<5`I!y~0L5zPRfEt+w=h?)JM9p?vAIsT=J{@9g|62k!2Fu!2TrI) zKe}x z;6oDJOe{M0fjiyk;5IoQMH}AXVYYcZU&A&x9YTrufx^us|lvguC{%z z?fBs)222R{DA3Pfj+wUCU`*_AK+C!fW*~9k8_jBe!XOBJlnP!jK za?LbJX6&Bc|-#3_0c;P2SG%J@#IPKLfbHwa?zq5Chnb^Oytn zL57@AV-DGe8S<=x9I=lw{lh^1@M}<`!)MDaQ8*U-Pi3|e)CI!l-6G+>5;5>>>Ku*eD4*^ z_Em;_-F}N9UjyVdhP-WGV94u$%ra!o{su$d0OU=E%-a_k@^wJoV#p=?9frIO$OVSH zYhPx_93bCd$QAoNhRiF-H|?toxd;ex?~CkvHuR7_uNoUXvql+23aPbt#1pZBt6&eenDv=Uet|Tz~w-oOwfz z_$|9CM=UBWtl1W0S+a{*43^`f^qJOcxlHDU)ApSJCLS2!nq#!Q*36ab23!mP-il!v zmzS2_H+~rHHmtyCVx2TL z+;DB$2s-sO!wPsN#KKzb-AhX~pri|lF~B0!bOc6Xt+*zUkeD$4(5rimp0^OI1agHL z@2%C=!mu6GY6f^zt8E16_P)vS?>fGClV#h`29`X%2FnO;Rq)tp^7_+8+w;S6tv0P* zfIDrAXu9UL9Nb}%c3SQ|Bk<~XoG_Rcuch0#>#nf$@3g#)R?j4S&kL)BNz4N}xdI&F z8YDpz=@ut6sOfcDA@ritLhK>%5bIdYa2rpz9o({w(3AQ_qrpZ@XSow5N=RBx9QD0U zD3qD7G_A0{2L0-pU)R(yNw$wf79<^OC4}bHYKn|)JVuP-Z&I8EyplrsZlW&5KvyT; zKGE}PX-eWTc>#m0JMLXF4QN!i7W6#oJ54V{7zC*flyAM^!j>TBR$|hLrAzg$R17FU zfUpEO9D8=wc(HPxg&*ZR;mXWwaS^<3Sam1f&z9hT51`ZY5y(~9;^QeB0p4~P2S7dJ zuEk@a-w7Znjxd7qP+SnE6c>c@<3HSv>amf<1eCwb5B^IJeuIcb(SVmnyH{zUnUD4&2b0X z5KnMB@owh=s|6XKlkTe0-i%Ats@rnIYV{uQ1(Rqpqr=$(en+#D*@9lsqewGQ~YMZlK<~~x$=m0pY{|HItkF#|5 zLnNB_^-uK{_(}iIXU-$d3?Y>V+Ikk_a$DMubUP1hIb0QfOlw>5S~PyzZQZpRE}Q$T z@mMQA*4})q8If*$6zLzoRnEs*1hetbrF)d^K(pgqxY>4y;+EBPs#RuoIqScU+4>jI z#2VZqU2yXTK`-!uAmq91BzEf856jVgPgE z06HP@0#>#TDX+uw)?sx&%#k%&-v!HvJ#aD<5Rk`I{w6R^liy@-?zWgGy&jb_L`Ygu z+O+&TW$EIGFW=ZSY{6AT5o#1d0C0b{_Gw}#6(oBW$mrDJNt~e4pU2kJ!w{WtI3zpY zYhqdet#n#-(z%LUtm;;af*i0ES)y$$Z^9Rc6x=90QkaU^UPoFZC9n+JU0HD`PculB z6XZ>IbuCng@R}ADjUcf6OpuhH{6o~xA~2AHqg2`mf+~kDe}z%OIGRj; z7>9i?Pw9=sL%35dRA%@9PWi`KGQ#Mr#0OT1psyzzFnAFrGpFF` zvGz8|;Wdg@*i=mhk~6f@X*4+g`x^`vZY3M-O6ITb_D!A~5Gw@vV4(nadHs#PU8^nm z9T{|zvil;3=?%sq-M~SSBMqsQd`?s5vq<6Vt;I!n3$g+Fd5hi|XAwxpc@C|y?(xz- zNYjVhpekPQ_lmH5N|?IaN0@SqB$a;02vYM8^1N((Kz@-pq$nisr{Y2pJ53uRfTzew z3XesosG_8;M}Xym{~TV;q{TUUdVAP0fL>lN|B)!A`Db#vw&#mzBoQN4hdw%$MeoD- zemWnJ``4n%RrijQENnni<1n6RMCi`0tatADbngBl5O+;|z^voavW03P@cuK#CfcXs zo8)HS+*Rl})i?JCWHDOQA=xB~M`G!f1~FYpq@wZ{)>a5g31_D~NH_tx!lW7s!&9Q` zB7Y#|97==opDN1pX=In&?4vx3(QJ0)byBH4(3$F!gQ*sU0VonD_Z5U#+h#d%f~0vQ z8meLUi6*((H$kOVM|vjsFe~Et^&A@z#}?5KXu5>Spa77yDG`}U+(Xngdc7U3k61^Q zjNI@Pl{Q*40hUc03rfZKfZ|Zphh>%~m-3!0N2cQBS6EW8x|5i(a43`q#97o_IcxCG z(v1N;;s^g7H-*vVb#31l={ib;MMwHWl^udIa&F4^&;o924>>G*sN4D@tf2R`FuO&o z1G5nS3wD-+v|RMT9Fz>=<!jL zSgBH_uE+jJg($OT2k`+qP!fb-wgv^#?d%=h-)F<}Bs5PdwWZlPgladU$xycoq+k!U z2l_3nQ=HOr`lwcdl}zFnb%A}Um9TM0G|^--zhw5-Z_A`^`;CNoy>=6bS};nQslhan zZ@{el#5mZTW<(Nn3q@lp1(NZ=P!Q2`rkom};_L=l1EPADQZtmICH?qM*-T)hCc43PG2!Mfp2i>jbD;11)dL0ShdVvOG6vqI`)m7o~j?n?eJ{6B!xMd&{9EjXNa@ zp#vdqFKu>%F7L+GvLT?8Dz(pjm zs}9~7I;%dMD{^P2e#bbyaAm$MU8kB&msl#s>1!y3&LZB&NSfWM=ZUI{jhZEra(Y$0 zj!l79Xf+fHpIL8UDA zM`-yUC>#@eH6(FAdb|W-%ZrZ!xBhVwR`#wgNKw5Fv9yR>R8az*qKy!DWpkQ~NkoZA zNfEa!V-seDXdtM}Z;jJ8Z(Ql)DeTGX_;q9)RMgm5bFq~{4@sk+!84p;3H^n3P;Ev{ z;sh%&=s5umYEbmPDjx6FSdvcD4KUkA!?DYiICl~2W%R`oUPHZP%cz%fDz$ZOWKrBj z0jGL3oq7P@yQZAz5(RlU?Xc>$@CDU=LK!wMohcHdAFwR#y1YWQ7x+6Q!toX?o+fma(B@OLeUD1QWE1sbKyDE-2fu5gY`^ zM2!L=J%Wly`UAwI)f^Y!bJyZMC?-&)kk4_zq^qweFILzX3DmV#3n9yMmzNf;}rEl)Ruy!l0ZyQ!Hs|5}VxKnfnyT zZ0A1WOFjA%va#g(?t(L|e#mfsBTf;ugE_?lMBKn}c@Lkyb4m*D)U0uenS1Jf55t}X z35eem!v=C{A|Zuz(`p8;VpstT+n;Fewo!e2Q|3r~6Ujf4Lyqnr&~dY@wGPC@y7#dS z*t7=wYp4$I?ZY96#5&cB-re{av23|@upG%xh;2{lW4OT0Q50e!)WKVu@PRTrQhI7N zJn77(3&J*6(8f6{F1x!_il0O6tSzS6^$NLKDn#OV7Q(}2hgJw!h${Qub)Ahi@=+D# zz%BCr{2Qn%Y&h6L#rB8Sy_9TXqZ5(f!rX`Kwn3P1n+iAW3Sg2*YvH|8N1e_uT^P)Q z;Ir^-S^p@+(&f+w`Lco_m+VZ`R7%l!B7SkJPwHe??5ldE{s`p&F8k<_cU9KO69pnM zLCnc6GqyreGojT}@iZwH?6}2}9s$Jp1zsXkx_wea)Vg-}(mO$ygNUA##{t#!K2_xB zqXP-~+XwvyjQAvBgf!Z(fDiNC2Qd3t5slBG#NQ5Q+f_iMY)7+ zV|L~V?G&dj;Sth!cBFria3t9x>Sc*QkG)MJ$qljd(n74xhmUZips6$lArTCtNwFRs zOF(XrWNGqLjjbCyTRaBRS!0Lmr1-%YpdTfpWZM0@Petl4^$3c0f1m_4 z)F&u4s7Fu~!YS8Co7hRQiz}r%3R^lHB<%)dqm8sax}(FBZfL&iJaa;`;&75TW8L(c zl&aKeG?y)K{5d^)Cl~}4jWN0zO7t;6?K4tU$lps1X;@PJ8Dnf5=3?;n>Q8`?kBCbg zXyr$>Xm8>~p0ug*4_&Zay^^9y}cv z=vduX&x$dyBE{^7#En6IZVY5%$HNhf__HoXD4pmT@zmV-Lkc2AA}53{%6<0CB2?c= zq)+KM&Or2L(p@Ui=dQkjTznU4OV4beHv6BfHoHhOm@;|IFJB=53#kzp;~+?FKVCYW9L@f8E72m2nRk_tb3b(KzxmH)w&YC93w6 zT2%uEMnETr_$UIF!ENOo<<(O)P0m`LuY672W&gyu5Q7|ivZ9fHLSb^%`CG-Rp&tLl zH=mk6-|1E>p3axDrkfH)%CGIB1%CCMzYAo8dfL)`f_Kg{bw5$0m!h%6v7~X=JTNkg9-)<1bJcB&67vAvHx(Vc z4N)=hp_Dq&pq>|JX63Q2ptCFv&3Dz3``5Lumt!{KyB|g%OMmP@X)Q(Apym*Q4sl!_ zqv%T@S;P}C6m-P-X{fFBlsZowTJE?F)G`qTQW4Ils-{ilS=#rsx#qOtVqr&)ODA;c z7<1Pi0!1yid5$Mjb_!WMLDPoQ@jq4SHX2PO>XzPqYFj%)tgQ8Xi3`DmEpklxrcdm{C!`d!b{aSwACFe6pLDE-I4Y0NhpRXUg2V9Xshcr+9~~Tu zwJ^>t(Y6a^eDOrJYPIl*7Jp$C;1N2WzHR!K33i;CtJEw|gRkB3=4B6g z?hU%WK+O_0H>sh+E8+m%ZR(L4#iQi5;7i1g5*>z!ClgRo%P~h1NYj4BEG3(soFK$G ziUrM49LA{14YEMg?OC3=i`ZB2oAkP2YFgBANzyiXar zPkT~+hnl<8kTv-9DTlvF%?LFSH55|$-=XFiYVK1*Yl;6Unz$ew99NXhW82)ebpG-q zW!iqEN{Kn+1Gz)sW{M&~y^fx(-|1@?2{|k7dj+y+j04RQS zJ+J?Q=RrNZLD!fY<(asEDh6UU{|Ce&l3qN74{}fm#rYJUN-yR(#Wt`3`7wgf2NoUc z2rB^F0;>^AoQ;j`lU0VbifmJ80Vxj-`r>0jQRC!Tf~!NcJ1LS|E{t&Yafo2Nb;{v5 z?K#9b9McTMR{^X@q*5jaNE{mnzCjQDE)B)kV=l(BIg(lV&rx%d8q$YBiV~OJ6kg~p U=t(Ac2Te&E#o43(<8StV0S+sSG5`Po literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/response.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/response.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..42696f0c76976c856473c8dd12585d11c68e82c1 GIT binary patch literal 22607 zcmeHv+jCq;df%KggTdfRkmCKO!;3_YL=34r1yPhBkd!EqfR+GP)>!u7VEO>DjBa$CR{n6s6E z;uDgeKz?^|x8!#szo)oI^1G^gYx|1(B>x2R`-}S}zZ>}j#RHPxgZ#nbLCNn${!sCd zECix@CA1@x4{88jj z6i-P0N#su!PfFfF{;A?ql0Sz0)5WJHf4q9CcDi^P`O{wBvu-`(7m%8lq^h6gEmh=rj9{=PJ(+kR8(5c`wAnh-%fErE;TjyFws438XZ? zFuibdzBDs;>GC`ZCsw==RqCNv4@=>ClNCp2+-h~nE#JOWDHG1uE5vhUX@AV)f4in(F`j9U5bl`R>QDaBKA;csOkEFSJLed>W4B1A#=kh zy6vL3X3jn*)qOi*+6K*T*|07%UG3ISTgGEr2Eb=L#v{7!+S*#lP0YVrVfcHkM(CBi z&|SeSMqBls=N%eQsp&VGo*%B~)16G+t$CfaYLq)!-wRuQy-b3L{xZl6;giNEP)L*& zf-l^+e~?0u=j~1=@T$xHDfC_je~SM&PLA&he1g+RFfxn}W3vF; zR<=q5Hpcc@>X!XQ`ZMc+wPD?}0Y5VfsKW*sK=4-B?1ys}*ac)ZQo;VuQlDA3Qg>4R zetv(JdOcO&wUP3l*+_k1J&<>wr7mC$^Qni{>_fXVsCx*o4;%3k`Og4a-u9oum!C)S zF!g9!O?|XdZLL(jkDBXuy!xFN3a@^2t+Mn{Pzk-sCUy=8G5BcB^KZAk*2>wytp}CH zS>NoALUX+{)TozQO_CJx6y%VktZ{4D%2@3}i9{4Fdf`H~QFg1r#lkZ7YWFDykk9yB za^GPxiKLT8#fP?x)_)EK4=ou!zBmE@9P4BV?P=r!u1U(;n{6NZihlEHY1f<3u=wAHHh47z6Q%p#vF#=RYSKgVUmwhp zSGR7&Cp5Q^8YA9#_gf9B-2DMHq=s?+J>iY3k^7b!Rb!uKio3l%-k3a(s~w+a?pejX z-rigLP&TM0?%Qf-T)M}!+ohh6di%Zos27b^=7Ki6(PmFvqvtK^a?E2Kt<>AA_F)7E zRESc}TVv*+u3<*6Ashle4ljcPcIPDZImaXTXItda|DpTC>aaS3c^*}*81B}3NAC}+ zCzXSGPXYr+1Ovy^ahaKek_aL(bwZt#@?+jH%y`_)@~OC#wU4tenHgJ9z9247cqe6C zr&V4(^SNDo$~&o^RfFEs-YInkB?HCNrpBZyNR2#doJ9@LhdL)Uo-s9^Q_o9{XU+2q z>P2}zW1e49FU#{JAiM$y1@EjnFA&b5iajmG`FR2fu z-HbQ$743>~t%w4DS$!n!E_s(syCd;v{Eop( zSt-HGRlN7){j$7&7tbp~U#s%`9_n91FBNr5-G)?LW$InKbzRj|9TYl?_j7pPP)&LN zJ$XNe_rAP;UkySgSo0}DxFJrj8(tGfD}>9yfsEF$DfIAOzi{@l5OJeygXWu9`Ti61QI z)Z*WWQ3TP<#b{b($k<*`ct@*Pi%w(dmRAnX#BgQU)k+YO)D{;{-}cteI3gtF7Z;td zg%u`QVhz?R)hcNK+SVON^B@F_$&CRmE=GMso%9U025pe~nO+n=Iec_Z100n%{j`SV zXn<@?r?&6}Ej_9ITNNHu(EBQ*JVYvmA z_8?&MoZ?>RfOB6q$x^FQRirXbUe9&eZ;-$u9J60(SSUDX2HCwXgPodko-dq}H|>E| zxIB6OCqD)gY7YxmnpL+_ul(f>hv@8vgF8*Vlvh)l- z!EYf6QyWm%AU*Gb+LbEV_5B+*h|0PLH3v__kgjdY(ItB$qf)JuzqFB-?{^iYYx|Dn zzl-nm-L#Zj{;!4^sBfuT1NUr}-OWfl%MUj)tgq|~klzKuCwR`@h4c>SgOt$o>Dfoo z_$Nt$k0SHH{Fr9)1ELpzZ6a1AH}=QpdpLSc=X=j>I&ZG2ehWbyg>2a zX6_v(B2r5tB6Y4*0@lM)sg9R{gCsRNY~>(L58K0b&e~;V@idC(9CU#kp4vMju2+cK z=B@rJC09aL;UF?pr8iRdtXtL(p;8l1_)h<5KorzR)`hn1{Bqm=m5bEUiI@(CMs2-R z@?{<`0Y;zE`#8NyrO)v)5QVCDeEMyV9!*`B9~oE{84QIBW3`VhfTHEBGh9}fw###& z-l{Emet|{?SdDnn!7>7)QNKZrBr5z)Jg#&*Ht!S?6{znEB+>U}257=R=J}CvQXvx} z5`9~%d6wV>y0vJfH&J5~di({H{VqNlGxlE{4f=c`8U_s-`e8uE^#^gk>GqD8V)V>0 zX3;AUs^sruneDjZq=Qww{=N=dEkk1)Ou zQ+4|s_~}MwYcKi1*`IJ{`Aph-F4vmj`sPJw+vl7|mebBTH)r3Qo%>)mKdM)Sc+$%; z$lNs~oq+&y8;k~3uihE{E-fc|fd(sqs;pE(e?)4vD2#P-?|JL;I^uppVq_h~QGpY! zCwIl>Rs0ZTe}YeN5=lxp-6$*{qgYLTPo&3fJlVE&5WH~0&ZXOXW18-vmQL!Cb@obr zxRZt?BUIiQthpc4wAvZ;K5kYZ4Rtb2H(c#xRilO@52qXr!Qgka$WqenAK~g+JzL^N4o{xz`sKm@9}$tcsb9fsO3O;6@H_ct~Y7hLrvJ$OHN{Xl=~6PXO2R z9)uGYhd-^`=D4QVIqj^ueqDsf!13J*1@4NLYl2D}a*EFDc1F^7ypPMCr@F%8lpBWr z)FS7tE0)+6;wCi$iVa$H)FNFF8o>?%S7IPWXaN?dqzN+4X`TnM;AO@D2?$c5H0A{O zXWEKzqFZY@rDyP3HcC`C%QO`!9e^4!eoh;!)TpaKB<;mnI2ItqnX@+!6vdK~j3AM4 zzGkRKn}Mth(UK|+&X#Heq7=TRTD1Z`b*hWV1Q^LK`Hi&zS`DN_N>y8?Us{I9D=w=(+0fk1&k5OMrGSIfUvD-yL6UB_carN^b0RV5;(N0 z{)li;ce&B%t?PJUx!^c+K#;$NO?M{Vn|g$#mhHfSPPZA9OofxHU}r@rF`Gj(ohb)O z%i`jK-}0yqCTLX<6Y1UV9k){DtYavIcBkTsxHP{7c*M!3oJ*AeW`f3=^Dbb_m;Fi; zD_Jgsez~sQ{xd&#RpcaBLL z1b+o|1r4}@6Fvk##I`4&R}C+yp9-<9VHo)4X98To=uUN4*pR+vZst^r7#nxJ;m_Dm zrYRT@I5g>Rv$-MKP4cZ-A&HqeXO-++P9<>0N*ztHt8vIiZOkwdyso3^LrDG(sq=Wi?LY8!AN;-;f*A52WM^TV)&F$Nx$&&VfG=W$3ZA=f0P>gM~wRLhHgf!-iV%)K7;bz7O{h`Dz z5fYOMXiiBD(8?hej=yYA#2nI8dpvR}fIomHw_*9mfmUc;4}e-|ROtsWEvStC0J-ND zz$79pJjVD)ks$A1#poVcuL&v68rQD>JPQ4fkU&L($+sELwY+(*f*^#~7$13h)XrGD z?1T*`8cdJU+CxEm(GQhYP!Wu1NNr^qzrQ`}zl*n62Vzl9I&E+2rzvx(p65siJ=JTC zAh|*-5wZ>F@I`O~$h0T$A`Wd(11kFf7CSX~Aa&Qq(5Oc<&>`3Uk3IP9T5Bm`gMPz8 zQd~4N9+Pj6B@~u*W3F8dYt`2xlkn?ew}jxRxjn4?u=()m6@kki3VX6K`HKI!5H1xV4+5;k1uWdqeT@g zYMljLn-wiA65;ShyewAx*_iwz(kKZYgFdknLY@8+!4%m;#;2Fvf07Bi6hbwz57Lny zf$%>W21n4@v8kh%IT|si4DC+uwc7i)8&NTL4Y3_`>$HE&g^!+M2g{^UG?yzLyhvD5 zaUkJr_B{nnyd1_D=W?Q;(xe8))7yn+W?V+vHjfikD=;^-I5~Oq##OpjVi3?Mpo55$ zDK?{v;7Qg8(>eT9becsKpj&!tabw>L8ZE!<75oc8NijXW;<+Qh1E+=jHZuan-tpG8 z@(2$e43Y`u5h8B|K89Fec5CqNh@XXeAA~Lhh6ov>ZwWgSuLKmn#Gu5GCPU7PETsK& zl!hQ)5N8b^h8TF&JRg?+1buVNqIAQ`0D+rM#k#iwNOve)l`*g?U0&V_`~zn&JL7^B zzXC=V4?$py;$09{)BexI$c%Q{h{@a`V#D=KOC6t993-LwD_u_!jmwb|VcOC=i8<(% zXNxW=G<>?{WUk_jYjibzR($93^d-QD+Xz0mxG(KZ5*bW0hgBEzUh<$eOE0Ugif5?1 z(}W^5T<7h}3x)Q0G|6jTeFdQQ8fxe*{u;BVZW8xqC^Io{nO?Lc+Rjbv%*`xZUck~M zuo46LD(nanwqPY;JBpzs#(+kkr|nQBAdM2Ik=R{KLDfWzlZYMsw}k|i#B9Oz*uxaA zPk%`Jkzow+-~t#GwRf9aPqt>4A<$FJWz+ERRjxL~P$qN|!-$-;bXe;dng;aRiVj?% zAwj%n33d~Bq{<3FZZ#BC~1?B!TyWa~jbB@SVF3YI1ZdjfRqN1_cefECCpxXgTEEY79bC zQ1{5|?wLv9xLgAS5W^0mO~U}pa1abXF&TFSYXubG#Hf@j4aS(zwsSiuj1iuw{p$k`ZNT3_t8zf03Jpjxgutu8 zP+2KsXu83qbb{$|NzXt3eBxm23VtNn6;CC+;*o)X^C1KonU0ts()q}U_DL5u`h-29 zICxn*7GjCPJoh6$vEFtuaaPZM8NP;iI$cD>k^y?h#tpE*keuk#sUkjST4xZg05W1< z{yJ8vYp3K|))9LmaYACHWWcrFUa;n})whe7_SiL;+9$7TMyA^TgNW@Z>WiV6i3x|` zLd2*M{zK`hhhBPwATS>=o;wn@LK(=f(1;CEih+pz-*8u0r{eN&fi$+Lt{F&|Gx!8= zA)#HMtGX&1p%42N-GxwL;Z&Ro(_du5fm_)JRyc^5bvP?k`g3a^R9ZL;@g&})1;g}i zAh3LWa+;LH<4GjS-i=rWH;Rs0YUqix=B0BlIH%_!L{=b^-mJ&==6no_d^=hgXB7rz zahzbc#^|FA%I2U|_(8yx^jX3ly8xrZ%!m`*&SmksB-UYp3yjTcJU(a+7ZqVva4h2# zqdZTlNHqBtmhRCAE+_z_E-}ihE`w$~FdfIbm0!X#`c$Yp>3U<$=kj*at+4D-VqrjNh_)>tP{!W?y!J?fu#9nCdyF}2{{WL$ne;O`{2E^T zd(Mn5(-gv4OlS*&TXI%0^Ig|pZ~r-&0&|Ym5;qAl!UO0-flO?O#!z)kc+!q66-a>77p$Y{}8Wo1>z zl43Vwf)&h#ljP(P!UojE5TgE#M9b+LQBT7b$)ivln5I|Cyy=nuTMNuz>Tiypx^-E@u<5(oStxOu%LObOxK98Kj5v#* zf}|*_t^|updr#%#wh`Aa^gVURkfM7_Ut!wgt)(z^k4~d(`=0|x&I|tXpji%OE^49gjxD0|sA3O^ZiiEr6fH7MtzKBGdU?t&%r`2vu z_AgBNGTO&j@S>Ymig&j3O)JAIdv02>tjiT2=`JQs7wxeg{P<^pW?1@u9bf${egB2r zknu?Ib*cP~=w4ON(EC~YJ|XOkPiE>LV$wZ_Uf^S|T~EgFXK{anyR)`6{$;|0(bFHp z{&7kkPUO;`}3;u&AUV{1jTEr$JQ>rgzx zSQL~)qK44;3XHEwlVi-6X`hJA0+?wGLq{`$v))E`3?fJfbR3=_ifB3|!Gfn27sdX7 zXP7fRc?7ay_N_4#CkES<1*53vbA?xWmOl-&(!R}a5yZdR+o3OVGBywnycA*q=^Md6 zM6K-S8J2_c2iyNfP`XG)iK9*<8bdbriXPL>W8?J=5Lv7!YzPY9mM{?LIk>u@W5P^F zLVWP0_e68`#Yv1YGS0MLUwI6>bbu~gOdTh)q(E864N19*nqZI*5nnw<)<_h{rNp+Iu!vXPb!dJGIUahx{4fM%{#CEq z6m_x;D>_ZMu%p9`hGPeJpu~s`+qAx?XRM-KuKEyMwH!1bL-!8W>g#aTeGylUhBw)i zAFgQc+h)o__uz-Wiw^qH{iT@DG^c$bCbWnRMm?2uPyLAh_X+$rk$_X}VEzb`?l$-> zKK9C`ooFVwO|B7b;7`TeYZwd{RuE7>R5oqOLcpjTDw`X9E3EhTIO@O4q@PveAK}GZ zJl4$PIqhG|cC2i_9rf}|!XN=fc#@LT|4UnQ@`fJw93!$LX-T%JgWcok$;G=$v zcy*jI;xB@M1!WomIDA5i;V=hq_foCYUXmEb*Vw!MKfogQFj$~p&P|E^aPaVTHtmUR zHf?gP+9$Sb;H?WPo7w+|=(gWh_BL(hHy*cZN*Yxqk-Fnw=!k!l!@tjtxUKy^VA5|F zM^oFpA(Nns92W(#)CjfD(JwP;+11?xcAH(D1oExy@E>wo+wSlm@$F-FIOzdZv_ecV zF|xSg@U+`MhKH6^$lIY3dV-%oft5oH@BwbOYSRa5IMJPgu&Xg9VzqfU4M!r(k+{wp zxglW|TCR#oF0wL0!-_Pru4ODTYW5j|SZiQO=Kv(EKMEu<0K2N_BZo>N;{Hjb_$8uA zF*{Apbf*Pthw%HZXeIn!v{U0}kL)oe*m@dkrNn^#Cb3L3rm_i9AHGa2$Dm3qL7IJ|I}nO(q5M?~KHe~3n~J8%}AbhFXy%k}>; z-u{52mB=XAukphyhx_8@9evrlef|USXlj<$U46)sU5j8}H~gKxXvddgk9{9ux++W@=AkjllIgj(VwtIVXCzr7v=$8GM8~ zsYXUU{V@uCNqYP7{{%1o6}s^MDKhOJ%C;6SGk3W|n;qiu;XTFi3D=8oDdvS?e;hh1 zexudYbS#TKsi`AAWAPJTa_ciFz`28)gNeuxSb2GyH{xcIF(m%&0^VLJ%*@TbzX*>& zt5$$=^-nm9KSI(OG`F41Ug%kl%K(dCWB4WuvWp#Tho*lUq3N#)?f))<*Z$M@;THl! zfKGzj0vcmFAc^~*_~sT%A{auB_8}O1x@s_HBSt&Cqzu!b$6^JB5^ai&A&XB-UtN35 zs>A@dTb;|@)tSW~F3v9jg|oAMnO|3~@FGr}wXWp9<9~ ztNM~TZZwxLPTV%X#-+H<j++Z@pWPz`60Tg~dUte?oki}^xSR^!C#zKUh%u=IKl^X_r zlkY+%45;?sWYT7G5=kc)MXmY=S;iRQVj3(*F8_DNBXI}bGsF~jCgNukIM*$KYffUT ziX%~-ntI7UN}vbWQHCCHxfxL$V?YDZ%5X8|{~GIDk~)ZfSTA-vF|NVlfE>fxkMQfP z{kNI?07-F-ys#N+BU_-2Xur+3V&3@s%7?|V3?k(;yg(^oE+X6I%v7Z1vIDrvAK z+-L&}HyWr<;l6mdrviBunMzcp%SL0KEx+YM5|m#w#gE_}$fWT<3~4t5Lo;u1|8Lvg z4K*7-l4c$L(&m4b7ar`t7=3a)ZCex2B6peZquHmAOB;Rn+qC9QlwH zr*ZVWGh>|`ks492-S1J1Zen-lbk;ydy$Rg6IgTHan?PHT>fena|N`H_yChc;R3#j7@h<4(E@;+%k-|v8x>WY$pSSqG$$$Fb!T$@MAKH@u literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/utils.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/__pycache__/utils.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..4e8a07df0671f511e2513fc3d3bc8f6e90fa24fb GIT binary patch literal 3860 zcmcInO>Y~=8Q$4lQY1~uiefZY+6GfMiOrOyjW~ydNSy>uiwFpq!m?3Ra7(T^Lusw$ zEiKl=ikp~(Wk4P_YWGJergzej932+jqn6Zye%et5hVUN*b113ewc*g%2vhpD@k>{ zw6$dWRrG6HHRj2>WcM4gzV69$V(CdBYNGxq+-izdOIfxQc7GXMEAyH2>)yy;_aNcs ztu#h;(Rfl3=S1^SWouQu0&dcMqJh?+@hg^h`AJo*i1XlG6KvCKtv$mjyxub(ZHtx7 zzD$Riko{Ps5ys1#a+s^wOn<3VrZCaKsBf}SDpR*#Y{-7yc8NSA>tk z1Ao>m{K7kA2f=T=^g`&FVEP&J==WQ=V$-_@`A@yyr3YaV9)+Uvl&Q1`MO7^Q5ym?R zMeU%HhJqbbtfml}s?hWUtLZNbO>maeRV{*DUww^nZPP0%s#gR@6;Us$uX)hibMp^+ z)|8Fezi#fx;VzFyJmO>wK90F_FF8qC1mm+32U4 z8pCKac@g?_6^+MgY}KFrl)TrEb$@Q_&WA}hj1qmLb0Sl+jyea4-tB+VUOTO7*@!hP zW}^d(QK_O(y8y11WJy! znmQki;)i|f+^ssM9MxLHH7gJ<&%bm4@{R7G@#-N9{RXT0t5u&h@vHeY*1)&whrXL> zV5aJ?fuhzS(W;bHjW9%FpR;OrWF(}*q*REBa(NMuMAR+}$nA@#f)0&u;?-ZHLH30O z+@CYGR-m7D3gkFOALB~_5#k%J14!*$_}CK_H}ly0Dgf0JRfN$18SaTCkQehzzP%G`K8h7MZQg3jJQ$oZ+hAaGGB%erPmy~QCACaV zn>bUOP=kRp>|ns5E!R?XEF#zq*gVbBWXgwGYLK9Ig-NE6#Uo1OSX(6`9*v}eV$dVU zM1d(HCAj5YoMfUhlMS9FgL zd6G2)js>}jVl8>(_~b*deYr@<4u;Y$s5@sa8k~H77_!k>m~^4&KytBpyFDcz8CIc(yl zJ6P!o`KN7-+ZqhoJX3Z>LR=6hk=beUUY1G_Z5ZWg{E+KxxGN39huG%#z?pP94e$%Q z+dw#Tfw&vC%jpnphwO`xNaYaQjns6$hI7aNc0reJj?-R;BaRO=--%OMdOeHQ77Y~@ zPdDhQFa3R8hGhO((0%{fv;Vw!@xl>;eXYxib<8a6zW3hsXWxQ0tI+QGY?Y#(GGnnw zD^RaNpT#0YK+>wH*JYbtj;0m5HhMP}>M}C1ah3-F^H$mZ}Z~^s@5yuIy1ujqh{=dplS#ly1 zsy|yf=ye*P)fPd2^1r`os}>!?VYlQ^$;e3S^gFjcw?P{5c~-eXBIVf}9|-#hY|_gv zDv*hLF$#k=VGyM~DhN#p2?Qcm)IbVF4HX;dFv-D*&SI%!^pu-K7WLE6!7$Q@-vQpt5$Pn(QK{+wZIz|KIBW^Qmhn$E zZ*FY-f3U`Z429ttq}q=(4kTdmtiw0u@vav!dls~gs-i@F&OVwoyKlesi=VyulXos(X|?f( zBh=AIqSC73#5jVY#4E%5S)3}$IVu;CmXorY*zf5?R+qt`u29n=)&LRlGFqG`%i|9Z zU7U!LWCx6zu*SPUMNxyT_!k)U@byEC*L?LZs4c(OYXv?W None: + self.buffer = bytearray() + self.complete = False + self.max_form_memory_size = max_form_memory_size + self.state = State.PREAMBLE + self.boundary = boundary + + # Note in the below \h i.e. horizontal whitespace is used + # as [^\S\n\r] as \h isn't supported in python. + + # The preamble must end with a boundary where the boundary is + # prefixed by a line break, RFC2046. Except that many + # implementations including Werkzeug's tests omit the line + # break prefix. In addition the first boundary could be the + # epilogue boundary (for empty form-data) hence the matching + # group to understand if it is an epilogue boundary. + self.preamble_re = re.compile( + br"%s?--%s(--[^\S\n\r]*%s?|[^\S\n\r]*%s)" + % (LINE_BREAK, re.escape(boundary), LINE_BREAK, LINE_BREAK), + re.MULTILINE, + ) + # A boundary must include a line break prefix and suffix, and + # may include trailing whitespace. In addition the boundary + # could be the epilogue boundary hence the matching group to + # understand if it is an epilogue boundary. + self.boundary_re = re.compile( + br"%s--%s(--[^\S\n\r]*%s?|[^\S\n\r]*%s)" + % (LINE_BREAK, re.escape(boundary), LINE_BREAK, LINE_BREAK), + re.MULTILINE, + ) + + def last_newline(self) -> int: + try: + last_nl = self.buffer.rindex(b"\n") + except ValueError: + last_nl = len(self.buffer) + try: + last_cr = self.buffer.rindex(b"\r") + except ValueError: + last_cr = len(self.buffer) + + return min(last_nl, last_cr) + + def receive_data(self, data: Optional[bytes]) -> None: + if data is None: + self.complete = True + elif ( + self.max_form_memory_size is not None + and len(self.buffer) + len(data) > self.max_form_memory_size + ): + raise RequestEntityTooLarge() + else: + self.buffer.extend(data) + + def next_event(self) -> Event: + event: Event = NEED_DATA + + if self.state == State.PREAMBLE: + match = self.preamble_re.search(self.buffer) + if match is not None: + if match.group(1).startswith(b"--"): + self.state = State.EPILOGUE + else: + self.state = State.PART + data = bytes(self.buffer[: match.start()]) + del self.buffer[: match.end()] + event = Preamble(data=data) + + elif self.state == State.PART: + match = BLANK_LINE_RE.search(self.buffer) + if match is not None: + headers = self._parse_headers(self.buffer[: match.start()]) + del self.buffer[: match.end()] + + if "content-disposition" not in headers: + raise ValueError("Missing Content-Disposition header") + + disposition, extra = parse_options_header( + headers["content-disposition"] + ) + name = cast(str, extra.get("name")) + filename = extra.get("filename") + if filename is not None: + event = File( + filename=filename, + headers=headers, + name=name, + ) + else: + event = Field( + headers=headers, + name=name, + ) + self.state = State.DATA + + elif self.state == State.DATA: + if self.buffer.find(b"--" + self.boundary) == -1: + # No complete boundary in the buffer, but there may be + # a partial boundary at the end. As the boundary + # starts with either a nl or cr find the earliest and + # return up to that as data. + data_length = del_index = self.last_newline() + more_data = True + else: + match = self.boundary_re.search(self.buffer) + if match is not None: + if match.group(1).startswith(b"--"): + self.state = State.EPILOGUE + else: + self.state = State.PART + data_length = match.start() + del_index = match.end() + else: + data_length = del_index = self.last_newline() + more_data = match is None + + data = bytes(self.buffer[:data_length]) + del self.buffer[:del_index] + if data or not more_data: + event = Data(data=data, more_data=more_data) + + elif self.state == State.EPILOGUE and self.complete: + event = Epilogue(data=bytes(self.buffer)) + del self.buffer[:] + self.state = State.COMPLETE + + if self.complete and isinstance(event, NeedData): + raise ValueError(f"Invalid form-data cannot parse beyond {self.state}") + + return event + + def _parse_headers(self, data: bytes) -> Headers: + headers: List[Tuple[str, str]] = [] + # Merge the continued headers into one line + data = HEADER_CONTINUATION_RE.sub(b" ", data) + # Now there is one header per line + for line in data.splitlines(): + if line.strip() != b"": + name, value = _to_str(line).strip().split(":", 1) + headers.append((name.strip(), value.strip())) + return Headers(headers) + + +class MultipartEncoder: + def __init__(self, boundary: bytes) -> None: + self.boundary = boundary + self.state = State.PREAMBLE + + def send_event(self, event: Event) -> bytes: + if isinstance(event, Preamble) and self.state == State.PREAMBLE: + self.state = State.PART + return event.data + elif isinstance(event, (Field, File)) and self.state in { + State.PREAMBLE, + State.PART, + State.DATA, + }: + self.state = State.DATA + data = b"\r\n--" + self.boundary + b"\r\n" + data += b'Content-Disposition: form-data; name="%s"' % _to_bytes(event.name) + if isinstance(event, File): + data += b'; filename="%s"' % _to_bytes(event.filename) + data += b"\r\n" + for name, value in cast(Field, event).headers: + if name.lower() != "content-disposition": + data += _to_bytes(f"{name}: {value}\r\n") + data += b"\r\n" + return data + elif isinstance(event, Data) and self.state == State.DATA: + return event.data + elif isinstance(event, Epilogue): + self.state = State.COMPLETE + return b"\r\n--" + self.boundary + b"--\r\n" + event.data + else: + raise ValueError(f"Cannot generate {event} in state: {self.state}") diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/request.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/request.py new file mode 100644 index 00000000..2c21a213 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/request.py @@ -0,0 +1,548 @@ +import typing as t +from datetime import datetime + +from .._internal import _to_str +from ..datastructures import Accept +from ..datastructures import Authorization +from ..datastructures import CharsetAccept +from ..datastructures import ETags +from ..datastructures import Headers +from ..datastructures import HeaderSet +from ..datastructures import IfRange +from ..datastructures import ImmutableList +from ..datastructures import ImmutableMultiDict +from ..datastructures import LanguageAccept +from ..datastructures import MIMEAccept +from ..datastructures import MultiDict +from ..datastructures import Range +from ..datastructures import RequestCacheControl +from ..http import parse_accept_header +from ..http import parse_authorization_header +from ..http import parse_cache_control_header +from ..http import parse_cookie +from ..http import parse_date +from ..http import parse_etags +from ..http import parse_if_range_header +from ..http import parse_list_header +from ..http import parse_options_header +from ..http import parse_range_header +from ..http import parse_set_header +from ..urls import url_decode +from ..user_agent import UserAgent +from ..useragents import _UserAgent as _DeprecatedUserAgent +from ..utils import cached_property +from ..utils import header_property +from .utils import get_current_url +from .utils import get_host + + +class Request: + """Represents the non-IO parts of a HTTP request, including the + method, URL info, and headers. + + This class is not meant for general use. It should only be used when + implementing WSGI, ASGI, or another HTTP application spec. Werkzeug + provides a WSGI implementation at :cls:`werkzeug.wrappers.Request`. + + :param method: The method the request was made with, such as + ``GET``. + :param scheme: The URL scheme of the protocol the request used, such + as ``https`` or ``wss``. + :param server: The address of the server. ``(host, port)``, + ``(path, None)`` for unix sockets, or ``None`` if not known. + :param root_path: The prefix that the application is mounted under. + This is prepended to generated URLs, but is not part of route + matching. + :param path: The path part of the URL after ``root_path``. + :param query_string: The part of the URL after the "?". + :param headers: The headers received with the request. + :param remote_addr: The address of the client sending the request. + + .. versionadded:: 2.0 + """ + + #: The charset used to decode most data in the request. + charset = "utf-8" + + #: the error handling procedure for errors, defaults to 'replace' + encoding_errors = "replace" + + #: the class to use for `args` and `form`. The default is an + #: :class:`~werkzeug.datastructures.ImmutableMultiDict` which supports + #: multiple values per key. alternatively it makes sense to use an + #: :class:`~werkzeug.datastructures.ImmutableOrderedMultiDict` which + #: preserves order or a :class:`~werkzeug.datastructures.ImmutableDict` + #: which is the fastest but only remembers the last key. It is also + #: possible to use mutable structures, but this is not recommended. + #: + #: .. versionadded:: 0.6 + parameter_storage_class: t.Type[MultiDict] = ImmutableMultiDict + + #: The type to be used for dict values from the incoming WSGI + #: environment. (For example for :attr:`cookies`.) By default an + #: :class:`~werkzeug.datastructures.ImmutableMultiDict` is used. + #: + #: .. versionchanged:: 1.0.0 + #: Changed to ``ImmutableMultiDict`` to support multiple values. + #: + #: .. versionadded:: 0.6 + dict_storage_class: t.Type[MultiDict] = ImmutableMultiDict + + #: the type to be used for list values from the incoming WSGI environment. + #: By default an :class:`~werkzeug.datastructures.ImmutableList` is used + #: (for example for :attr:`access_list`). + #: + #: .. versionadded:: 0.6 + list_storage_class: t.Type[t.List] = ImmutableList + + user_agent_class = _DeprecatedUserAgent + """The class used and returned by the :attr:`user_agent` property to + parse the header. Defaults to + :class:`~werkzeug.user_agent.UserAgent`, which does no parsing. An + extension can provide a subclass that uses a parser to provide other + data. + + .. versionadded:: 2.0 + """ + + #: Valid host names when handling requests. By default all hosts are + #: trusted, which means that whatever the client says the host is + #: will be accepted. + #: + #: Because ``Host`` and ``X-Forwarded-Host`` headers can be set to + #: any value by a malicious client, it is recommended to either set + #: this property or implement similar validation in the proxy (if + #: the application is being run behind one). + #: + #: .. versionadded:: 0.9 + trusted_hosts: t.Optional[t.List[str]] = None + + def __init__( + self, + method: str, + scheme: str, + server: t.Optional[t.Tuple[str, t.Optional[int]]], + root_path: str, + path: str, + query_string: bytes, + headers: Headers, + remote_addr: t.Optional[str], + ) -> None: + #: The method the request was made with, such as ``GET``. + self.method = method.upper() + #: The URL scheme of the protocol the request used, such as + #: ``https`` or ``wss``. + self.scheme = scheme + #: The address of the server. ``(host, port)``, ``(path, None)`` + #: for unix sockets, or ``None`` if not known. + self.server = server + #: The prefix that the application is mounted under, without a + #: trailing slash. :attr:`path` comes after this. + self.root_path = root_path.rstrip("/") + #: The path part of the URL after :attr:`root_path`. This is the + #: path used for routing within the application. + self.path = "/" + path.lstrip("/") + #: The part of the URL after the "?". This is the raw value, use + #: :attr:`args` for the parsed values. + self.query_string = query_string + #: The headers received with the request. + self.headers = headers + #: The address of the client sending the request. + self.remote_addr = remote_addr + + def __repr__(self) -> str: + try: + url = self.url + except Exception as e: + url = f"(invalid URL: {e})" + + return f"<{type(self).__name__} {url!r} [{self.method}]>" + + @property + def url_charset(self) -> str: + """The charset that is assumed for URLs. Defaults to the value + of :attr:`charset`. + + .. versionadded:: 0.6 + """ + return self.charset + + @cached_property + def args(self) -> "MultiDict[str, str]": + """The parsed URL parameters (the part in the URL after the question + mark). + + By default an + :class:`~werkzeug.datastructures.ImmutableMultiDict` + is returned from this function. This can be changed by setting + :attr:`parameter_storage_class` to a different type. This might + be necessary if the order of the form data is important. + """ + return url_decode( + self.query_string, + self.url_charset, + errors=self.encoding_errors, + cls=self.parameter_storage_class, + ) + + @cached_property + def access_route(self) -> t.List[str]: + """If a forwarded header exists this is a list of all ip addresses + from the client ip to the last proxy server. + """ + if "X-Forwarded-For" in self.headers: + return self.list_storage_class( + parse_list_header(self.headers["X-Forwarded-For"]) + ) + elif self.remote_addr is not None: + return self.list_storage_class([self.remote_addr]) + return self.list_storage_class() + + @cached_property + def full_path(self) -> str: + """Requested path, including the query string.""" + return f"{self.path}?{_to_str(self.query_string, self.url_charset)}" + + @property + def is_secure(self) -> bool: + """``True`` if the request was made with a secure protocol + (HTTPS or WSS). + """ + return self.scheme in {"https", "wss"} + + @cached_property + def url(self) -> str: + """The full request URL with the scheme, host, root path, path, + and query string.""" + return get_current_url( + self.scheme, self.host, self.root_path, self.path, self.query_string + ) + + @cached_property + def base_url(self) -> str: + """Like :attr:`url` but without the query string.""" + return get_current_url(self.scheme, self.host, self.root_path, self.path) + + @cached_property + def root_url(self) -> str: + """The request URL scheme, host, and root path. This is the root + that the application is accessed from. + """ + return get_current_url(self.scheme, self.host, self.root_path) + + @cached_property + def host_url(self) -> str: + """The request URL scheme and host only.""" + return get_current_url(self.scheme, self.host) + + @cached_property + def host(self) -> str: + """The host name the request was made to, including the port if + it's non-standard. Validated with :attr:`trusted_hosts`. + """ + return get_host( + self.scheme, self.headers.get("host"), self.server, self.trusted_hosts + ) + + @cached_property + def cookies(self) -> "ImmutableMultiDict[str, str]": + """A :class:`dict` with the contents of all cookies transmitted with + the request.""" + wsgi_combined_cookie = ";".join(self.headers.getlist("Cookie")) + return parse_cookie( # type: ignore + wsgi_combined_cookie, + self.charset, + self.encoding_errors, + cls=self.dict_storage_class, + ) + + # Common Descriptors + + content_type = header_property[str]( + "Content-Type", + doc="""The Content-Type entity-header field indicates the media + type of the entity-body sent to the recipient or, in the case of + the HEAD method, the media type that would have been sent had + the request been a GET.""", + read_only=True, + ) + + @cached_property + def content_length(self) -> t.Optional[int]: + """The Content-Length entity-header field indicates the size of the + entity-body in bytes or, in the case of the HEAD method, the size of + the entity-body that would have been sent had the request been a + GET. + """ + if self.headers.get("Transfer-Encoding", "") == "chunked": + return None + + content_length = self.headers.get("Content-Length") + if content_length is not None: + try: + return max(0, int(content_length)) + except (ValueError, TypeError): + pass + + return None + + content_encoding = header_property[str]( + "Content-Encoding", + doc="""The Content-Encoding entity-header field is used as a + modifier to the media-type. When present, its value indicates + what additional content codings have been applied to the + entity-body, and thus what decoding mechanisms must be applied + in order to obtain the media-type referenced by the Content-Type + header field. + + .. versionadded:: 0.9""", + read_only=True, + ) + content_md5 = header_property[str]( + "Content-MD5", + doc="""The Content-MD5 entity-header field, as defined in + RFC 1864, is an MD5 digest of the entity-body for the purpose of + providing an end-to-end message integrity check (MIC) of the + entity-body. (Note: a MIC is good for detecting accidental + modification of the entity-body in transit, but is not proof + against malicious attacks.) + + .. versionadded:: 0.9""", + read_only=True, + ) + referrer = header_property[str]( + "Referer", + doc="""The Referer[sic] request-header field allows the client + to specify, for the server's benefit, the address (URI) of the + resource from which the Request-URI was obtained (the + "referrer", although the header field is misspelled).""", + read_only=True, + ) + date = header_property( + "Date", + None, + parse_date, + doc="""The Date general-header field represents the date and + time at which the message was originated, having the same + semantics as orig-date in RFC 822. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """, + read_only=True, + ) + max_forwards = header_property( + "Max-Forwards", + None, + int, + doc="""The Max-Forwards request-header field provides a + mechanism with the TRACE and OPTIONS methods to limit the number + of proxies or gateways that can forward the request to the next + inbound server.""", + read_only=True, + ) + + def _parse_content_type(self) -> None: + if not hasattr(self, "_parsed_content_type"): + self._parsed_content_type = parse_options_header( + self.headers.get("Content-Type", "") + ) + + @property + def mimetype(self) -> str: + """Like :attr:`content_type`, but without parameters (eg, without + charset, type etc.) and always lowercase. For example if the content + type is ``text/HTML; charset=utf-8`` the mimetype would be + ``'text/html'``. + """ + self._parse_content_type() + return self._parsed_content_type[0].lower() + + @property + def mimetype_params(self) -> t.Dict[str, str]: + """The mimetype parameters as dict. For example if the content + type is ``text/html; charset=utf-8`` the params would be + ``{'charset': 'utf-8'}``. + """ + self._parse_content_type() + return self._parsed_content_type[1] + + @cached_property + def pragma(self) -> HeaderSet: + """The Pragma general-header field is used to include + implementation-specific directives that might apply to any recipient + along the request/response chain. All pragma directives specify + optional behavior from the viewpoint of the protocol; however, some + systems MAY require that behavior be consistent with the directives. + """ + return parse_set_header(self.headers.get("Pragma", "")) + + # Accept + + @cached_property + def accept_mimetypes(self) -> MIMEAccept: + """List of mimetypes this client supports as + :class:`~werkzeug.datastructures.MIMEAccept` object. + """ + return parse_accept_header(self.headers.get("Accept"), MIMEAccept) + + @cached_property + def accept_charsets(self) -> CharsetAccept: + """List of charsets this client supports as + :class:`~werkzeug.datastructures.CharsetAccept` object. + """ + return parse_accept_header(self.headers.get("Accept-Charset"), CharsetAccept) + + @cached_property + def accept_encodings(self) -> Accept: + """List of encodings this client accepts. Encodings in a HTTP term + are compression encodings such as gzip. For charsets have a look at + :attr:`accept_charset`. + """ + return parse_accept_header(self.headers.get("Accept-Encoding")) + + @cached_property + def accept_languages(self) -> LanguageAccept: + """List of languages this client accepts as + :class:`~werkzeug.datastructures.LanguageAccept` object. + + .. versionchanged 0.5 + In previous versions this was a regular + :class:`~werkzeug.datastructures.Accept` object. + """ + return parse_accept_header(self.headers.get("Accept-Language"), LanguageAccept) + + # ETag + + @cached_property + def cache_control(self) -> RequestCacheControl: + """A :class:`~werkzeug.datastructures.RequestCacheControl` object + for the incoming cache control headers. + """ + cache_control = self.headers.get("Cache-Control") + return parse_cache_control_header(cache_control, None, RequestCacheControl) + + @cached_property + def if_match(self) -> ETags: + """An object containing all the etags in the `If-Match` header. + + :rtype: :class:`~werkzeug.datastructures.ETags` + """ + return parse_etags(self.headers.get("If-Match")) + + @cached_property + def if_none_match(self) -> ETags: + """An object containing all the etags in the `If-None-Match` header. + + :rtype: :class:`~werkzeug.datastructures.ETags` + """ + return parse_etags(self.headers.get("If-None-Match")) + + @cached_property + def if_modified_since(self) -> t.Optional[datetime]: + """The parsed `If-Modified-Since` header as a datetime object. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """ + return parse_date(self.headers.get("If-Modified-Since")) + + @cached_property + def if_unmodified_since(self) -> t.Optional[datetime]: + """The parsed `If-Unmodified-Since` header as a datetime object. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """ + return parse_date(self.headers.get("If-Unmodified-Since")) + + @cached_property + def if_range(self) -> IfRange: + """The parsed ``If-Range`` header. + + .. versionchanged:: 2.0 + ``IfRange.date`` is timezone-aware. + + .. versionadded:: 0.7 + """ + return parse_if_range_header(self.headers.get("If-Range")) + + @cached_property + def range(self) -> t.Optional[Range]: + """The parsed `Range` header. + + .. versionadded:: 0.7 + + :rtype: :class:`~werkzeug.datastructures.Range` + """ + return parse_range_header(self.headers.get("Range")) + + # User Agent + + @cached_property + def user_agent(self) -> UserAgent: + """The user agent. Use ``user_agent.string`` to get the header + value. Set :attr:`user_agent_class` to a subclass of + :class:`~werkzeug.user_agent.UserAgent` to provide parsing for + the other properties or other extended data. + + .. versionchanged:: 2.0 + The built in parser is deprecated and will be removed in + Werkzeug 2.1. A ``UserAgent`` subclass must be set to parse + data from the string. + """ + return self.user_agent_class(self.headers.get("User-Agent", "")) + + # Authorization + + @cached_property + def authorization(self) -> t.Optional[Authorization]: + """The `Authorization` object in parsed form.""" + return parse_authorization_header(self.headers.get("Authorization")) + + # CORS + + origin = header_property[str]( + "Origin", + doc=( + "The host that the request originated from. Set" + " :attr:`~CORSResponseMixin.access_control_allow_origin` on" + " the response to indicate which origins are allowed." + ), + read_only=True, + ) + + access_control_request_headers = header_property( + "Access-Control-Request-Headers", + load_func=parse_set_header, + doc=( + "Sent with a preflight request to indicate which headers" + " will be sent with the cross origin request. Set" + " :attr:`~CORSResponseMixin.access_control_allow_headers`" + " on the response to indicate which headers are allowed." + ), + read_only=True, + ) + + access_control_request_method = header_property[str]( + "Access-Control-Request-Method", + doc=( + "Sent with a preflight request to indicate which method" + " will be used for the cross origin request. Set" + " :attr:`~CORSResponseMixin.access_control_allow_methods`" + " on the response to indicate which methods are allowed." + ), + read_only=True, + ) + + @property + def is_json(self) -> bool: + """Check if the mimetype indicates JSON data, either + :mimetype:`application/json` or :mimetype:`application/*+json`. + """ + mt = self.mimetype + return ( + mt == "application/json" + or mt.startswith("application/") + and mt.endswith("+json") + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/response.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/response.py new file mode 100644 index 00000000..82817e8c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/response.py @@ -0,0 +1,704 @@ +import typing as t +from datetime import datetime +from datetime import timedelta +from datetime import timezone +from http import HTTPStatus + +from .._internal import _to_str +from ..datastructures import Headers +from ..datastructures import HeaderSet +from ..http import dump_cookie +from ..http import HTTP_STATUS_CODES +from ..utils import get_content_type +from werkzeug.datastructures import CallbackDict +from werkzeug.datastructures import ContentRange +from werkzeug.datastructures import ContentSecurityPolicy +from werkzeug.datastructures import ResponseCacheControl +from werkzeug.datastructures import WWWAuthenticate +from werkzeug.http import COEP +from werkzeug.http import COOP +from werkzeug.http import dump_age +from werkzeug.http import dump_header +from werkzeug.http import dump_options_header +from werkzeug.http import http_date +from werkzeug.http import parse_age +from werkzeug.http import parse_cache_control_header +from werkzeug.http import parse_content_range_header +from werkzeug.http import parse_csp_header +from werkzeug.http import parse_date +from werkzeug.http import parse_options_header +from werkzeug.http import parse_set_header +from werkzeug.http import parse_www_authenticate_header +from werkzeug.http import quote_etag +from werkzeug.http import unquote_etag +from werkzeug.utils import header_property + + +def _set_property(name: str, doc: t.Optional[str] = None) -> property: + def fget(self: "Response") -> HeaderSet: + def on_update(header_set: HeaderSet) -> None: + if not header_set and name in self.headers: + del self.headers[name] + elif header_set: + self.headers[name] = header_set.to_header() + + return parse_set_header(self.headers.get(name), on_update) + + def fset( + self: "Response", + value: t.Optional[ + t.Union[str, t.Dict[str, t.Union[str, int]], t.Iterable[str]] + ], + ) -> None: + if not value: + del self.headers[name] + elif isinstance(value, str): + self.headers[name] = value + else: + self.headers[name] = dump_header(value) + + return property(fget, fset, doc=doc) + + +class Response: + """Represents the non-IO parts of an HTTP response, specifically the + status and headers but not the body. + + This class is not meant for general use. It should only be used when + implementing WSGI, ASGI, or another HTTP application spec. Werkzeug + provides a WSGI implementation at :cls:`werkzeug.wrappers.Response`. + + :param status: The status code for the response. Either an int, in + which case the default status message is added, or a string in + the form ``{code} {message}``, like ``404 Not Found``. Defaults + to 200. + :param headers: A :class:`~werkzeug.datastructures.Headers` object, + or a list of ``(key, value)`` tuples that will be converted to a + ``Headers`` object. + :param mimetype: The mime type (content type without charset or + other parameters) of the response. If the value starts with + ``text/`` (or matches some other special cases), the charset + will be added to create the ``content_type``. + :param content_type: The full content type of the response. + Overrides building the value from ``mimetype``. + + .. versionadded:: 2.0 + """ + + #: the charset of the response. + charset = "utf-8" + + #: the default status if none is provided. + default_status = 200 + + #: the default mimetype if none is provided. + default_mimetype = "text/plain" + + #: Warn if a cookie header exceeds this size. The default, 4093, should be + #: safely `supported by most browsers `_. A cookie larger than + #: this size will still be sent, but it may be ignored or handled + #: incorrectly by some browsers. Set to 0 to disable this check. + #: + #: .. versionadded:: 0.13 + #: + #: .. _`cookie`: http://browsercookielimits.squawky.net/ + max_cookie_size = 4093 + + # A :class:`Headers` object representing the response headers. + headers: Headers + + def __init__( + self, + status: t.Optional[t.Union[int, str, HTTPStatus]] = None, + headers: t.Optional[ + t.Union[ + t.Mapping[str, t.Union[str, int, t.Iterable[t.Union[str, int]]]], + t.Iterable[t.Tuple[str, t.Union[str, int]]], + ] + ] = None, + mimetype: t.Optional[str] = None, + content_type: t.Optional[str] = None, + ) -> None: + if isinstance(headers, Headers): + self.headers = headers + elif not headers: + self.headers = Headers() + else: + self.headers = Headers(headers) + + if content_type is None: + if mimetype is None and "content-type" not in self.headers: + mimetype = self.default_mimetype + if mimetype is not None: + mimetype = get_content_type(mimetype, self.charset) + content_type = mimetype + if content_type is not None: + self.headers["Content-Type"] = content_type + if status is None: + status = self.default_status + self.status = status # type: ignore + + def __repr__(self) -> str: + return f"<{type(self).__name__} [{self.status}]>" + + @property + def status_code(self) -> int: + """The HTTP status code as a number.""" + return self._status_code + + @status_code.setter + def status_code(self, code: int) -> None: + self.status = code # type: ignore + + @property + def status(self) -> str: + """The HTTP status code as a string.""" + return self._status + + @status.setter + def status(self, value: t.Union[str, int, HTTPStatus]) -> None: + if not isinstance(value, (str, bytes, int, HTTPStatus)): + raise TypeError("Invalid status argument") + + self._status, self._status_code = self._clean_status(value) + + def _clean_status(self, value: t.Union[str, int, HTTPStatus]) -> t.Tuple[str, int]: + if isinstance(value, HTTPStatus): + value = int(value) + status = _to_str(value, self.charset) + split_status = status.split(None, 1) + + if len(split_status) == 0: + raise ValueError("Empty status argument") + + if len(split_status) > 1: + if split_status[0].isdigit(): + # code and message + return status, int(split_status[0]) + + # multi-word message + return f"0 {status}", 0 + + if split_status[0].isdigit(): + # code only + status_code = int(split_status[0]) + + try: + status = f"{status_code} {HTTP_STATUS_CODES[status_code].upper()}" + except KeyError: + status = f"{status_code} UNKNOWN" + + return status, status_code + + # one-word message + return f"0 {status}", 0 + + def set_cookie( + self, + key: str, + value: str = "", + max_age: t.Optional[t.Union[timedelta, int]] = None, + expires: t.Optional[t.Union[str, datetime, int, float]] = None, + path: t.Optional[str] = "/", + domain: t.Optional[str] = None, + secure: bool = False, + httponly: bool = False, + samesite: t.Optional[str] = None, + ) -> None: + """Sets a cookie. + + A warning is raised if the size of the cookie header exceeds + :attr:`max_cookie_size`, but the header will still be set. + + :param key: the key (name) of the cookie to be set. + :param value: the value of the cookie. + :param max_age: should be a number of seconds, or `None` (default) if + the cookie should last only as long as the client's + browser session. + :param expires: should be a `datetime` object or UNIX timestamp. + :param path: limits the cookie to a given path, per default it will + span the whole domain. + :param domain: if you want to set a cross-domain cookie. For example, + ``domain=".example.com"`` will set a cookie that is + readable by the domain ``www.example.com``, + ``foo.example.com`` etc. Otherwise, a cookie will only + be readable by the domain that set it. + :param secure: If ``True``, the cookie will only be available + via HTTPS. + :param httponly: Disallow JavaScript access to the cookie. + :param samesite: Limit the scope of the cookie to only be + attached to requests that are "same-site". + """ + self.headers.add( + "Set-Cookie", + dump_cookie( + key, + value=value, + max_age=max_age, + expires=expires, + path=path, + domain=domain, + secure=secure, + httponly=httponly, + charset=self.charset, + max_size=self.max_cookie_size, + samesite=samesite, + ), + ) + + def delete_cookie( + self, + key: str, + path: str = "/", + domain: t.Optional[str] = None, + secure: bool = False, + httponly: bool = False, + samesite: t.Optional[str] = None, + ) -> None: + """Delete a cookie. Fails silently if key doesn't exist. + + :param key: the key (name) of the cookie to be deleted. + :param path: if the cookie that should be deleted was limited to a + path, the path has to be defined here. + :param domain: if the cookie that should be deleted was limited to a + domain, that domain has to be defined here. + :param secure: If ``True``, the cookie will only be available + via HTTPS. + :param httponly: Disallow JavaScript access to the cookie. + :param samesite: Limit the scope of the cookie to only be + attached to requests that are "same-site". + """ + self.set_cookie( + key, + expires=0, + max_age=0, + path=path, + domain=domain, + secure=secure, + httponly=httponly, + samesite=samesite, + ) + + @property + def is_json(self) -> bool: + """Check if the mimetype indicates JSON data, either + :mimetype:`application/json` or :mimetype:`application/*+json`. + """ + mt = self.mimetype + return mt is not None and ( + mt == "application/json" + or mt.startswith("application/") + and mt.endswith("+json") + ) + + # Common Descriptors + + @property + def mimetype(self) -> t.Optional[str]: + """The mimetype (content type without charset etc.)""" + ct = self.headers.get("content-type") + + if ct: + return ct.split(";")[0].strip() + else: + return None + + @mimetype.setter + def mimetype(self, value: str) -> None: + self.headers["Content-Type"] = get_content_type(value, self.charset) + + @property + def mimetype_params(self) -> t.Dict[str, str]: + """The mimetype parameters as dict. For example if the + content type is ``text/html; charset=utf-8`` the params would be + ``{'charset': 'utf-8'}``. + + .. versionadded:: 0.5 + """ + + def on_update(d: CallbackDict) -> None: + self.headers["Content-Type"] = dump_options_header(self.mimetype, d) + + d = parse_options_header(self.headers.get("content-type", ""))[1] + return CallbackDict(d, on_update) + + location = header_property[str]( + "Location", + doc="""The Location response-header field is used to redirect + the recipient to a location other than the Request-URI for + completion of the request or identification of a new + resource.""", + ) + age = header_property( + "Age", + None, + parse_age, + dump_age, # type: ignore + doc="""The Age response-header field conveys the sender's + estimate of the amount of time since the response (or its + revalidation) was generated at the origin server. + + Age values are non-negative decimal integers, representing time + in seconds.""", + ) + content_type = header_property[str]( + "Content-Type", + doc="""The Content-Type entity-header field indicates the media + type of the entity-body sent to the recipient or, in the case of + the HEAD method, the media type that would have been sent had + the request been a GET.""", + ) + content_length = header_property( + "Content-Length", + None, + int, + str, + doc="""The Content-Length entity-header field indicates the size + of the entity-body, in decimal number of OCTETs, sent to the + recipient or, in the case of the HEAD method, the size of the + entity-body that would have been sent had the request been a + GET.""", + ) + content_location = header_property[str]( + "Content-Location", + doc="""The Content-Location entity-header field MAY be used to + supply the resource location for the entity enclosed in the + message when that entity is accessible from a location separate + from the requested resource's URI.""", + ) + content_encoding = header_property[str]( + "Content-Encoding", + doc="""The Content-Encoding entity-header field is used as a + modifier to the media-type. When present, its value indicates + what additional content codings have been applied to the + entity-body, and thus what decoding mechanisms must be applied + in order to obtain the media-type referenced by the Content-Type + header field.""", + ) + content_md5 = header_property[str]( + "Content-MD5", + doc="""The Content-MD5 entity-header field, as defined in + RFC 1864, is an MD5 digest of the entity-body for the purpose of + providing an end-to-end message integrity check (MIC) of the + entity-body. (Note: a MIC is good for detecting accidental + modification of the entity-body in transit, but is not proof + against malicious attacks.)""", + ) + date = header_property( + "Date", + None, + parse_date, + http_date, + doc="""The Date general-header field represents the date and + time at which the message was originated, having the same + semantics as orig-date in RFC 822. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """, + ) + expires = header_property( + "Expires", + None, + parse_date, + http_date, + doc="""The Expires entity-header field gives the date/time after + which the response is considered stale. A stale cache entry may + not normally be returned by a cache. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """, + ) + last_modified = header_property( + "Last-Modified", + None, + parse_date, + http_date, + doc="""The Last-Modified entity-header field indicates the date + and time at which the origin server believes the variant was + last modified. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """, + ) + + @property + def retry_after(self) -> t.Optional[datetime]: + """The Retry-After response-header field can be used with a + 503 (Service Unavailable) response to indicate how long the + service is expected to be unavailable to the requesting client. + + Time in seconds until expiration or date. + + .. versionchanged:: 2.0 + The datetime object is timezone-aware. + """ + value = self.headers.get("retry-after") + if value is None: + return None + elif value.isdigit(): + return datetime.now(timezone.utc) + timedelta(seconds=int(value)) + return parse_date(value) + + @retry_after.setter + def retry_after(self, value: t.Optional[t.Union[datetime, int, str]]) -> None: + if value is None: + if "retry-after" in self.headers: + del self.headers["retry-after"] + return + elif isinstance(value, datetime): + value = http_date(value) + else: + value = str(value) + self.headers["Retry-After"] = value + + vary = _set_property( + "Vary", + doc="""The Vary field value indicates the set of request-header + fields that fully determines, while the response is fresh, + whether a cache is permitted to use the response to reply to a + subsequent request without revalidation.""", + ) + content_language = _set_property( + "Content-Language", + doc="""The Content-Language entity-header field describes the + natural language(s) of the intended audience for the enclosed + entity. Note that this might not be equivalent to all the + languages used within the entity-body.""", + ) + allow = _set_property( + "Allow", + doc="""The Allow entity-header field lists the set of methods + supported by the resource identified by the Request-URI. The + purpose of this field is strictly to inform the recipient of + valid methods associated with the resource. An Allow header + field MUST be present in a 405 (Method Not Allowed) + response.""", + ) + + # ETag + + @property + def cache_control(self) -> ResponseCacheControl: + """The Cache-Control general-header field is used to specify + directives that MUST be obeyed by all caching mechanisms along the + request/response chain. + """ + + def on_update(cache_control: ResponseCacheControl) -> None: + if not cache_control and "cache-control" in self.headers: + del self.headers["cache-control"] + elif cache_control: + self.headers["Cache-Control"] = cache_control.to_header() + + return parse_cache_control_header( + self.headers.get("cache-control"), on_update, ResponseCacheControl + ) + + def set_etag(self, etag: str, weak: bool = False) -> None: + """Set the etag, and override the old one if there was one.""" + self.headers["ETag"] = quote_etag(etag, weak) + + def get_etag(self) -> t.Union[t.Tuple[str, bool], t.Tuple[None, None]]: + """Return a tuple in the form ``(etag, is_weak)``. If there is no + ETag the return value is ``(None, None)``. + """ + return unquote_etag(self.headers.get("ETag")) + + accept_ranges = header_property[str]( + "Accept-Ranges", + doc="""The `Accept-Ranges` header. Even though the name would + indicate that multiple values are supported, it must be one + string token only. + + The values ``'bytes'`` and ``'none'`` are common. + + .. versionadded:: 0.7""", + ) + + @property + def content_range(self) -> ContentRange: + """The ``Content-Range`` header as a + :class:`~werkzeug.datastructures.ContentRange` object. Available + even if the header is not set. + + .. versionadded:: 0.7 + """ + + def on_update(rng: ContentRange) -> None: + if not rng: + del self.headers["content-range"] + else: + self.headers["Content-Range"] = rng.to_header() + + rv = parse_content_range_header(self.headers.get("content-range"), on_update) + # always provide a content range object to make the descriptor + # more user friendly. It provides an unset() method that can be + # used to remove the header quickly. + if rv is None: + rv = ContentRange(None, None, None, on_update=on_update) + return rv + + @content_range.setter + def content_range(self, value: t.Optional[t.Union[ContentRange, str]]) -> None: + if not value: + del self.headers["content-range"] + elif isinstance(value, str): + self.headers["Content-Range"] = value + else: + self.headers["Content-Range"] = value.to_header() + + # Authorization + + @property + def www_authenticate(self) -> WWWAuthenticate: + """The ``WWW-Authenticate`` header in a parsed form.""" + + def on_update(www_auth: WWWAuthenticate) -> None: + if not www_auth and "www-authenticate" in self.headers: + del self.headers["www-authenticate"] + elif www_auth: + self.headers["WWW-Authenticate"] = www_auth.to_header() + + header = self.headers.get("www-authenticate") + return parse_www_authenticate_header(header, on_update) + + # CSP + + @property + def content_security_policy(self) -> ContentSecurityPolicy: + """The ``Content-Security-Policy`` header as a + :class:`~werkzeug.datastructures.ContentSecurityPolicy` object. Available + even if the header is not set. + + The Content-Security-Policy header adds an additional layer of + security to help detect and mitigate certain types of attacks. + """ + + def on_update(csp: ContentSecurityPolicy) -> None: + if not csp: + del self.headers["content-security-policy"] + else: + self.headers["Content-Security-Policy"] = csp.to_header() + + rv = parse_csp_header(self.headers.get("content-security-policy"), on_update) + if rv is None: + rv = ContentSecurityPolicy(None, on_update=on_update) + return rv + + @content_security_policy.setter + def content_security_policy( + self, value: t.Optional[t.Union[ContentSecurityPolicy, str]] + ) -> None: + if not value: + del self.headers["content-security-policy"] + elif isinstance(value, str): + self.headers["Content-Security-Policy"] = value + else: + self.headers["Content-Security-Policy"] = value.to_header() + + @property + def content_security_policy_report_only(self) -> ContentSecurityPolicy: + """The ``Content-Security-policy-report-only`` header as a + :class:`~werkzeug.datastructures.ContentSecurityPolicy` object. Available + even if the header is not set. + + The Content-Security-Policy-Report-Only header adds a csp policy + that is not enforced but is reported thereby helping detect + certain types of attacks. + """ + + def on_update(csp: ContentSecurityPolicy) -> None: + if not csp: + del self.headers["content-security-policy-report-only"] + else: + self.headers["Content-Security-policy-report-only"] = csp.to_header() + + rv = parse_csp_header( + self.headers.get("content-security-policy-report-only"), on_update + ) + if rv is None: + rv = ContentSecurityPolicy(None, on_update=on_update) + return rv + + @content_security_policy_report_only.setter + def content_security_policy_report_only( + self, value: t.Optional[t.Union[ContentSecurityPolicy, str]] + ) -> None: + if not value: + del self.headers["content-security-policy-report-only"] + elif isinstance(value, str): + self.headers["Content-Security-policy-report-only"] = value + else: + self.headers["Content-Security-policy-report-only"] = value.to_header() + + # CORS + + @property + def access_control_allow_credentials(self) -> bool: + """Whether credentials can be shared by the browser to + JavaScript code. As part of the preflight request it indicates + whether credentials can be used on the cross origin request. + """ + return "Access-Control-Allow-Credentials" in self.headers + + @access_control_allow_credentials.setter + def access_control_allow_credentials(self, value: t.Optional[bool]) -> None: + if value is True: + self.headers["Access-Control-Allow-Credentials"] = "true" + else: + self.headers.pop("Access-Control-Allow-Credentials", None) + + access_control_allow_headers = header_property( + "Access-Control-Allow-Headers", + load_func=parse_set_header, + dump_func=dump_header, + doc="Which headers can be sent with the cross origin request.", + ) + + access_control_allow_methods = header_property( + "Access-Control-Allow-Methods", + load_func=parse_set_header, + dump_func=dump_header, + doc="Which methods can be used for the cross origin request.", + ) + + access_control_allow_origin = header_property[str]( + "Access-Control-Allow-Origin", + doc="The origin or '*' for any origin that may make cross origin requests.", + ) + + access_control_expose_headers = header_property( + "Access-Control-Expose-Headers", + load_func=parse_set_header, + dump_func=dump_header, + doc="Which headers can be shared by the browser to JavaScript code.", + ) + + access_control_max_age = header_property( + "Access-Control-Max-Age", + load_func=int, + dump_func=str, + doc="The maximum age in seconds the access control settings can be cached for.", + ) + + cross_origin_opener_policy = header_property[COOP]( + "Cross-Origin-Opener-Policy", + load_func=lambda value: COOP(value), + dump_func=lambda value: value.value, + default=COOP.UNSAFE_NONE, + doc="""Allows control over sharing of browsing context group with cross-origin + documents. Values must be a member of the :class:`werkzeug.http.COOP` enum.""", + ) + + cross_origin_embedder_policy = header_property[COEP]( + "Cross-Origin-Embedder-Policy", + load_func=lambda value: COEP(value), + dump_func=lambda value: value.value, + default=COEP.UNSAFE_NONE, + doc="""Prevents a document from loading any cross-origin resources that do not + explicitly grant the document permission. Values must be a member of the + :class:`werkzeug.http.COEP` enum.""", + ) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/utils.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/utils.py new file mode 100644 index 00000000..1b4d8920 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/sansio/utils.py @@ -0,0 +1,142 @@ +import typing as t + +from .._internal import _encode_idna +from ..exceptions import SecurityError +from ..urls import uri_to_iri +from ..urls import url_quote + + +def host_is_trusted(hostname: str, trusted_list: t.Iterable[str]) -> bool: + """Check if a host matches a list of trusted names. + + :param hostname: The name to check. + :param trusted_list: A list of valid names to match. If a name + starts with a dot it will match all subdomains. + + .. versionadded:: 0.9 + """ + if not hostname: + return False + + if isinstance(trusted_list, str): + trusted_list = [trusted_list] + + def _normalize(hostname: str) -> bytes: + if ":" in hostname: + hostname = hostname.rsplit(":", 1)[0] + + return _encode_idna(hostname) + + try: + hostname_bytes = _normalize(hostname) + except UnicodeError: + return False + + for ref in trusted_list: + if ref.startswith("."): + ref = ref[1:] + suffix_match = True + else: + suffix_match = False + + try: + ref_bytes = _normalize(ref) + except UnicodeError: + return False + + if ref_bytes == hostname_bytes: + return True + + if suffix_match and hostname_bytes.endswith(b"." + ref_bytes): + return True + + return False + + +def get_host( + scheme: str, + host_header: t.Optional[str], + server: t.Optional[t.Tuple[str, t.Optional[int]]] = None, + trusted_hosts: t.Optional[t.Iterable[str]] = None, +) -> str: + """Return the host for the given parameters. + + This first checks the ``host_header``. If it's not present, then + ``server`` is used. The host will only contain the port if it is + different than the standard port for the protocol. + + Optionally, verify that the host is trusted using + :func:`host_is_trusted` and raise a + :exc:`~werkzeug.exceptions.SecurityError` if it is not. + + :param scheme: The protocol the request used, like ``"https"``. + :param host_header: The ``Host`` header value. + :param server: Address of the server. ``(host, port)``, or + ``(path, None)`` for unix sockets. + :param trusted_hosts: A list of trusted host names. + + :return: Host, with port if necessary. + :raise ~werkzeug.exceptions.SecurityError: If the host is not + trusted. + """ + host = "" + + if host_header is not None: + host = host_header + elif server is not None: + host = server[0] + + if server[1] is not None: + host = f"{host}:{server[1]}" + + if scheme in {"http", "ws"} and host.endswith(":80"): + host = host[:-3] + elif scheme in {"https", "wss"} and host.endswith(":443"): + host = host[:-4] + + if trusted_hosts is not None: + if not host_is_trusted(host, trusted_hosts): + raise SecurityError(f"Host {host!r} is not trusted.") + + return host + + +def get_current_url( + scheme: str, + host: str, + root_path: t.Optional[str] = None, + path: t.Optional[str] = None, + query_string: t.Optional[bytes] = None, +) -> str: + """Recreate the URL for a request. If an optional part isn't + provided, it and subsequent parts are not included in the URL. + + The URL is an IRI, not a URI, so it may contain Unicode characters. + Use :func:`~werkzeug.urls.iri_to_uri` to convert it to ASCII. + + :param scheme: The protocol the request used, like ``"https"``. + :param host: The host the request was made to. See :func:`get_host`. + :param root_path: Prefix that the application is mounted under. This + is prepended to ``path``. + :param path: The path part of the URL after ``root_path``. + :param query_string: The portion of the URL after the "?". + """ + url = [scheme, "://", host] + + if root_path is None: + url.append("/") + return uri_to_iri("".join(url)) + + url.append(url_quote(root_path.rstrip("/"))) + url.append("/") + + if path is None: + return uri_to_iri("".join(url)) + + url.append(url_quote(path.lstrip("/"))) + + if query_string: + url.append("?") + url.append(url_quote(query_string, safe=":&%=+$!*'(),")) + + return uri_to_iri("".join(url)) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/security.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/security.py new file mode 100644 index 00000000..e23040af --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/security.py @@ -0,0 +1,247 @@ +import hashlib +import hmac +import os +import posixpath +import secrets +import typing as t +import warnings + +if t.TYPE_CHECKING: + pass + +SALT_CHARS = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789" +DEFAULT_PBKDF2_ITERATIONS = 260000 + +_os_alt_seps: t.List[str] = list( + sep for sep in [os.path.sep, os.path.altsep] if sep is not None and sep != "/" +) + + +def pbkdf2_hex( + data: t.Union[str, bytes], + salt: t.Union[str, bytes], + iterations: int = DEFAULT_PBKDF2_ITERATIONS, + keylen: t.Optional[int] = None, + hashfunc: t.Optional[t.Union[str, t.Callable]] = None, +) -> str: + """Like :func:`pbkdf2_bin`, but returns a hex-encoded string. + + :param data: the data to derive. + :param salt: the salt for the derivation. + :param iterations: the number of iterations. + :param keylen: the length of the resulting key. If not provided, + the digest size will be used. + :param hashfunc: the hash function to use. This can either be the + string name of a known hash function, or a function + from the hashlib module. Defaults to sha256. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :func:`hashlib.pbkdf2_hmac` + instead. + + .. versionadded:: 0.9 + """ + warnings.warn( + "'pbkdf2_hex' is deprecated and will be removed in Werkzeug" + " 2.1. Use 'hashlib.pbkdf2_hmac().hex()' instead.", + DeprecationWarning, + stacklevel=2, + ) + return pbkdf2_bin(data, salt, iterations, keylen, hashfunc).hex() + + +def pbkdf2_bin( + data: t.Union[str, bytes], + salt: t.Union[str, bytes], + iterations: int = DEFAULT_PBKDF2_ITERATIONS, + keylen: t.Optional[int] = None, + hashfunc: t.Optional[t.Union[str, t.Callable]] = None, +) -> bytes: + """Returns a binary digest for the PBKDF2 hash algorithm of `data` + with the given `salt`. It iterates `iterations` times and produces a + key of `keylen` bytes. By default, SHA-256 is used as hash function; + a different hashlib `hashfunc` can be provided. + + :param data: the data to derive. + :param salt: the salt for the derivation. + :param iterations: the number of iterations. + :param keylen: the length of the resulting key. If not provided + the digest size will be used. + :param hashfunc: the hash function to use. This can either be the + string name of a known hash function or a function + from the hashlib module. Defaults to sha256. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :func:`hashlib.pbkdf2_hmac` + instead. + + .. versionadded:: 0.9 + """ + warnings.warn( + "'pbkdf2_bin' is deprecated and will be removed in Werkzeug" + " 2.1. Use 'hashlib.pbkdf2_hmac()' instead.", + DeprecationWarning, + stacklevel=2, + ) + + if isinstance(data, str): + data = data.encode("utf8") + + if isinstance(salt, str): + salt = salt.encode("utf8") + + if not hashfunc: + hash_name = "sha256" + elif callable(hashfunc): + hash_name = hashfunc().name + else: + hash_name = hashfunc + + return hashlib.pbkdf2_hmac(hash_name, data, salt, iterations, keylen) + + +def safe_str_cmp(a: str, b: str) -> bool: + """This function compares strings in somewhat constant time. This + requires that the length of at least one string is known in advance. + + Returns `True` if the two strings are equal, or `False` if they are not. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use + :func:`hmac.compare_digest` instead. + + .. versionadded:: 0.7 + """ + warnings.warn( + "'safe_str_cmp' is deprecated and will be removed in Werkzeug" + " 2.1. Use 'hmac.compare_digest' instead.", + DeprecationWarning, + stacklevel=2, + ) + + if isinstance(a, str): + a = a.encode("utf-8") # type: ignore + + if isinstance(b, str): + b = b.encode("utf-8") # type: ignore + + return hmac.compare_digest(a, b) + + +def gen_salt(length: int) -> str: + """Generate a random string of SALT_CHARS with specified ``length``.""" + if length <= 0: + raise ValueError("Salt length must be positive") + + return "".join(secrets.choice(SALT_CHARS) for _ in range(length)) + + +def _hash_internal(method: str, salt: str, password: str) -> t.Tuple[str, str]: + """Internal password hash helper. Supports plaintext without salt, + unsalted and salted passwords. In case salted passwords are used + hmac is used. + """ + if method == "plain": + return password, method + + salt = salt.encode("utf-8") + password = password.encode("utf-8") + + if method.startswith("pbkdf2:"): + if not salt: + raise ValueError("Salt is required for PBKDF2") + + args = method[7:].split(":") + + if len(args) not in (1, 2): + raise ValueError("Invalid number of arguments for PBKDF2") + + method = args.pop(0) + iterations = int(args[0] or 0) if args else DEFAULT_PBKDF2_ITERATIONS + return ( + hashlib.pbkdf2_hmac(method, password, salt, iterations).hex(), + f"pbkdf2:{method}:{iterations}", + ) + + if salt: + return hmac.new(salt, password, method).hexdigest(), method + + return hashlib.new(method, password).hexdigest(), method + + +def generate_password_hash( + password: str, method: str = "pbkdf2:sha256", salt_length: int = 16 +) -> str: + """Hash a password with the given method and salt with a string of + the given length. The format of the string returned includes the method + that was used so that :func:`check_password_hash` can check the hash. + + The format for the hashed string looks like this:: + + method$salt$hash + + This method can **not** generate unsalted passwords but it is possible + to set param method='plain' in order to enforce plaintext passwords. + If a salt is used, hmac is used internally to salt the password. + + If PBKDF2 is wanted it can be enabled by setting the method to + ``pbkdf2:method:iterations`` where iterations is optional:: + + pbkdf2:sha256:80000$salt$hash + pbkdf2:sha256$salt$hash + + :param password: the password to hash. + :param method: the hash method to use (one that hashlib supports). Can + optionally be in the format ``pbkdf2:method:iterations`` + to enable PBKDF2. + :param salt_length: the length of the salt in letters. + """ + salt = gen_salt(salt_length) if method != "plain" else "" + h, actual_method = _hash_internal(method, salt, password) + return f"{actual_method}${salt}${h}" + + +def check_password_hash(pwhash: str, password: str) -> bool: + """Check a password against a given salted and hashed password value. + In order to support unsalted legacy passwords this method supports + plain text passwords, md5 and sha1 hashes (both salted and unsalted). + + Returns `True` if the password matched, `False` otherwise. + + :param pwhash: a hashed string like returned by + :func:`generate_password_hash`. + :param password: the plaintext password to compare against the hash. + """ + if pwhash.count("$") < 2: + return False + + method, salt, hashval = pwhash.split("$", 2) + return hmac.compare_digest(_hash_internal(method, salt, password)[0], hashval) + + +def safe_join(directory: str, *pathnames: str) -> t.Optional[str]: + """Safely join zero or more untrusted path components to a base + directory to avoid escaping the base directory. + + :param directory: The trusted base directory. + :param pathnames: The untrusted path components relative to the + base directory. + :return: A safe path, otherwise ``None``. + """ + parts = [directory] + + for filename in pathnames: + if filename != "": + filename = posixpath.normpath(filename) + + if ( + any(sep in filename for sep in _os_alt_seps) + or os.path.isabs(filename) + or filename == ".." + or filename.startswith("../") + ): + return None + + parts.append(filename) + + return posixpath.join(*parts) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/serving.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/serving.py new file mode 100644 index 00000000..197b6fb9 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/serving.py @@ -0,0 +1,1081 @@ +"""A WSGI and HTTP server for use **during development only**. This +server is convenient to use, but is not designed to be particularly +stable, secure, or efficient. Use a dedicate WSGI server and HTTP +server when deploying to production. + +It provides features like interactive debugging and code reloading. Use +``run_simple`` to start the server. Put this in a ``run.py`` script: + +.. code-block:: python + + from myapp import create_app + from werkzeug import run_simple +""" +import io +import os +import platform +import signal +import socket +import socketserver +import sys +import typing as t +import warnings +from datetime import datetime as dt +from datetime import timedelta +from datetime import timezone +from http.server import BaseHTTPRequestHandler +from http.server import HTTPServer + +from ._internal import _log +from ._internal import _wsgi_encoding_dance +from .exceptions import InternalServerError +from .urls import uri_to_iri +from .urls import url_parse +from .urls import url_unquote + +try: + import ssl +except ImportError: + + class _SslDummy: + def __getattr__(self, name: str) -> t.Any: + raise RuntimeError("SSL support unavailable") # noqa: B904 + + ssl = _SslDummy() # type: ignore + +_log_add_style = True + +if os.name == "nt": + try: + __import__("colorama") + except ImportError: + _log_add_style = False + +can_fork = hasattr(os, "fork") + +if can_fork: + ForkingMixIn = socketserver.ForkingMixIn +else: + + class ForkingMixIn: # type: ignore + pass + + +try: + af_unix = socket.AF_UNIX +except AttributeError: + af_unix = None # type: ignore + +LISTEN_QUEUE = 128 +can_open_by_fd = not platform.system() == "Windows" and hasattr(socket, "fromfd") + +_TSSLContextArg = t.Optional[ + t.Union["ssl.SSLContext", t.Tuple[str, t.Optional[str]], "te.Literal['adhoc']"] +] + +if t.TYPE_CHECKING: + import typing_extensions as te # noqa: F401 + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + from cryptography.hazmat.primitives.asymmetric.rsa import ( + RSAPrivateKeyWithSerialization, + ) + from cryptography.x509 import Certificate + + +class DechunkedInput(io.RawIOBase): + """An input stream that handles Transfer-Encoding 'chunked'""" + + def __init__(self, rfile: t.IO[bytes]) -> None: + self._rfile = rfile + self._done = False + self._len = 0 + + def readable(self) -> bool: + return True + + def read_chunk_len(self) -> int: + try: + line = self._rfile.readline().decode("latin1") + _len = int(line.strip(), 16) + except ValueError as e: + raise OSError("Invalid chunk header") from e + if _len < 0: + raise OSError("Negative chunk length not allowed") + return _len + + def readinto(self, buf: bytearray) -> int: # type: ignore + read = 0 + while not self._done and read < len(buf): + if self._len == 0: + # This is the first chunk or we fully consumed the previous + # one. Read the next length of the next chunk + self._len = self.read_chunk_len() + + if self._len == 0: + # Found the final chunk of size 0. The stream is now exhausted, + # but there is still a final newline that should be consumed + self._done = True + + if self._len > 0: + # There is data (left) in this chunk, so append it to the + # buffer. If this operation fully consumes the chunk, this will + # reset self._len to 0. + n = min(len(buf), self._len) + + # If (read + chunk size) becomes more than len(buf), buf will + # grow beyond the original size and read more data than + # required. So only read as much data as can fit in buf. + if read + n > len(buf): + buf[read:] = self._rfile.read(len(buf) - read) + self._len -= len(buf) - read + read = len(buf) + else: + buf[read : read + n] = self._rfile.read(n) + self._len -= n + read += n + + if self._len == 0: + # Skip the terminating newline of a chunk that has been fully + # consumed. This also applies to the 0-sized final chunk + terminator = self._rfile.readline() + if terminator not in (b"\n", b"\r\n", b"\r"): + raise OSError("Missing chunk terminating newline") + + return read + + +class WSGIRequestHandler(BaseHTTPRequestHandler): + """A request handler that implements WSGI dispatching.""" + + server: "BaseWSGIServer" + + @property + def server_version(self) -> str: # type: ignore + from . import __version__ + + return f"Werkzeug/{__version__}" + + def make_environ(self) -> "WSGIEnvironment": + request_url = url_parse(self.path) + + def shutdown_server() -> None: + warnings.warn( + "The 'environ['werkzeug.server.shutdown']' function is" + " deprecated and will be removed in Werkzeug 2.1.", + stacklevel=2, + ) + self.server.shutdown_signal = True + + url_scheme = "http" if self.server.ssl_context is None else "https" + + if not self.client_address: + self.client_address = ("", 0) + elif isinstance(self.client_address, str): + self.client_address = (self.client_address, 0) + + # If there was no scheme but the path started with two slashes, + # the first segment may have been incorrectly parsed as the + # netloc, prepend it to the path again. + if not request_url.scheme and request_url.netloc: + path_info = f"/{request_url.netloc}{request_url.path}" + else: + path_info = request_url.path + + path_info = url_unquote(path_info) + + environ: "WSGIEnvironment" = { + "wsgi.version": (1, 0), + "wsgi.url_scheme": url_scheme, + "wsgi.input": self.rfile, + "wsgi.errors": sys.stderr, + "wsgi.multithread": self.server.multithread, + "wsgi.multiprocess": self.server.multiprocess, + "wsgi.run_once": False, + "werkzeug.server.shutdown": shutdown_server, + "werkzeug.socket": self.connection, + "SERVER_SOFTWARE": self.server_version, + "REQUEST_METHOD": self.command, + "SCRIPT_NAME": "", + "PATH_INFO": _wsgi_encoding_dance(path_info), + "QUERY_STRING": _wsgi_encoding_dance(request_url.query), + # Non-standard, added by mod_wsgi, uWSGI + "REQUEST_URI": _wsgi_encoding_dance(self.path), + # Non-standard, added by gunicorn + "RAW_URI": _wsgi_encoding_dance(self.path), + "REMOTE_ADDR": self.address_string(), + "REMOTE_PORT": self.port_integer(), + "SERVER_NAME": self.server.server_address[0], + "SERVER_PORT": str(self.server.server_address[1]), + "SERVER_PROTOCOL": self.request_version, + } + + for key, value in self.headers.items(): + key = key.upper().replace("-", "_") + value = value.replace("\r\n", "") + if key not in ("CONTENT_TYPE", "CONTENT_LENGTH"): + key = f"HTTP_{key}" + if key in environ: + value = f"{environ[key]},{value}" + environ[key] = value + + if environ.get("HTTP_TRANSFER_ENCODING", "").strip().lower() == "chunked": + environ["wsgi.input_terminated"] = True + environ["wsgi.input"] = DechunkedInput(environ["wsgi.input"]) + + # Per RFC 2616, if the URL is absolute, use that as the host. + # We're using "has a scheme" to indicate an absolute URL. + if request_url.scheme and request_url.netloc: + environ["HTTP_HOST"] = request_url.netloc + + try: + # binary_form=False gives nicer information, but wouldn't be compatible with + # what Nginx or Apache could return. + peer_cert = self.connection.getpeercert(binary_form=True) + if peer_cert is not None: + # Nginx and Apache use PEM format. + environ["SSL_CLIENT_CERT"] = ssl.DER_cert_to_PEM_cert(peer_cert) + except ValueError: + # SSL handshake hasn't finished. + self.server.log("error", "Cannot fetch SSL peer certificate info") + except AttributeError: + # Not using TLS, the socket will not have getpeercert(). + pass + + return environ + + def run_wsgi(self) -> None: + if self.headers.get("Expect", "").lower().strip() == "100-continue": + self.wfile.write(b"HTTP/1.1 100 Continue\r\n\r\n") + + self.environ = environ = self.make_environ() + status_set: t.Optional[str] = None + headers_set: t.Optional[t.List[t.Tuple[str, str]]] = None + status_sent: t.Optional[str] = None + headers_sent: t.Optional[t.List[t.Tuple[str, str]]] = None + + def write(data: bytes) -> None: + nonlocal status_sent, headers_sent + assert status_set is not None, "write() before start_response" + assert headers_set is not None, "write() before start_response" + if status_sent is None: + status_sent = status_set + headers_sent = headers_set + try: + code_str, msg = status_sent.split(None, 1) + except ValueError: + code_str, msg = status_sent, "" + code = int(code_str) + self.send_response(code, msg) + header_keys = set() + for key, value in headers_sent: + self.send_header(key, value) + key = key.lower() + header_keys.add(key) + if not ( + "content-length" in header_keys + or environ["REQUEST_METHOD"] == "HEAD" + or code < 200 + or code in (204, 304) + ): + self.close_connection = True + self.send_header("Connection", "close") + if "server" not in header_keys: + self.send_header("Server", self.version_string()) + if "date" not in header_keys: + self.send_header("Date", self.date_time_string()) + self.end_headers() + + assert isinstance(data, bytes), "applications must write bytes" + self.wfile.write(data) + self.wfile.flush() + + def start_response(status, headers, exc_info=None): # type: ignore + nonlocal status_set, headers_set + if exc_info: + try: + if headers_sent: + raise exc_info[1].with_traceback(exc_info[2]) + finally: + exc_info = None + elif headers_set: + raise AssertionError("Headers already set") + status_set = status + headers_set = headers + return write + + def execute(app: "WSGIApplication") -> None: + application_iter = app(environ, start_response) + try: + for data in application_iter: + write(data) + if not headers_sent: + write(b"") + finally: + if hasattr(application_iter, "close"): + application_iter.close() # type: ignore + + try: + execute(self.server.app) + except (ConnectionError, socket.timeout) as e: + self.connection_dropped(e, environ) + except Exception: + if self.server.passthrough_errors: + raise + from .debug.tbtools import get_current_traceback + + traceback = get_current_traceback(ignore_system_exceptions=True) + try: + # if we haven't yet sent the headers but they are set + # we roll back to be able to set them again. + if status_sent is None: + status_set = None + headers_set = None + execute(InternalServerError()) + except Exception: + pass + self.server.log("error", "Error on request:\n%s", traceback.plaintext) + + def handle(self) -> None: + """Handles a request ignoring dropped connections.""" + try: + BaseHTTPRequestHandler.handle(self) + except (ConnectionError, socket.timeout) as e: + self.connection_dropped(e) + except Exception as e: + if self.server.ssl_context is not None and is_ssl_error(e): + self.log_error("SSL error occurred: %s", e) + else: + raise + if self.server.shutdown_signal: + self.initiate_shutdown() + + def initiate_shutdown(self) -> None: + if is_running_from_reloader(): + # Windows does not provide SIGKILL, go with SIGTERM then. + sig = getattr(signal, "SIGKILL", signal.SIGTERM) + os.kill(os.getpid(), sig) + + self.server._BaseServer__shutdown_request = True # type: ignore + + def connection_dropped( + self, error: BaseException, environ: t.Optional["WSGIEnvironment"] = None + ) -> None: + """Called if the connection was closed by the client. By default + nothing happens. + """ + + def handle_one_request(self) -> None: + """Handle a single HTTP request.""" + self.raw_requestline = self.rfile.readline() + if not self.raw_requestline: + self.close_connection = True + elif self.parse_request(): + self.run_wsgi() + + def send_response(self, code: int, message: t.Optional[str] = None) -> None: + """Send the response header and log the response code.""" + self.log_request(code) + if message is None: + message = self.responses[code][0] if code in self.responses else "" + if self.request_version != "HTTP/0.9": + hdr = f"{self.protocol_version} {code} {message}\r\n" + self.wfile.write(hdr.encode("ascii")) + + def version_string(self) -> str: + return super().version_string().strip() + + def address_string(self) -> str: + if getattr(self, "environ", None): + return self.environ["REMOTE_ADDR"] # type: ignore + + if not self.client_address: + return "" + + return self.client_address[0] + + def port_integer(self) -> int: + return self.client_address[1] + + def log_request( + self, code: t.Union[int, str] = "-", size: t.Union[int, str] = "-" + ) -> None: + try: + path = uri_to_iri(self.path) + msg = f"{self.command} {path} {self.request_version}" + except AttributeError: + # path isn't set if the requestline was bad + msg = self.requestline + + code = str(code) + + if _log_add_style: + if code[0] == "1": # 1xx - Informational + msg = _ansi_style(msg, "bold") + elif code == "200": # 2xx - Success + pass + elif code == "304": # 304 - Resource Not Modified + msg = _ansi_style(msg, "cyan") + elif code[0] == "3": # 3xx - Redirection + msg = _ansi_style(msg, "green") + elif code == "404": # 404 - Resource Not Found + msg = _ansi_style(msg, "yellow") + elif code[0] == "4": # 4xx - Client Error + msg = _ansi_style(msg, "bold", "red") + else: # 5xx, or any other response + msg = _ansi_style(msg, "bold", "magenta") + + self.log("info", '"%s" %s %s', msg, code, size) + + def log_error(self, format: str, *args: t.Any) -> None: + self.log("error", format, *args) + + def log_message(self, format: str, *args: t.Any) -> None: + self.log("info", format, *args) + + def log(self, type: str, message: str, *args: t.Any) -> None: + _log( + type, + f"{self.address_string()} - - [{self.log_date_time_string()}] {message}\n", + *args, + ) + + +def _ansi_style(value: str, *styles: str) -> str: + codes = { + "bold": 1, + "red": 31, + "green": 32, + "yellow": 33, + "magenta": 35, + "cyan": 36, + } + + for style in styles: + value = f"\x1b[{codes[style]}m{value}" + + return f"{value}\x1b[0m" + + +def generate_adhoc_ssl_pair( + cn: t.Optional[str] = None, +) -> t.Tuple["Certificate", "RSAPrivateKeyWithSerialization"]: + try: + from cryptography import x509 + from cryptography.x509.oid import NameOID + from cryptography.hazmat.backends import default_backend + from cryptography.hazmat.primitives import hashes + from cryptography.hazmat.primitives.asymmetric import rsa + except ImportError: + raise TypeError( + "Using ad-hoc certificates requires the cryptography library." + ) from None + + backend = default_backend() + pkey = rsa.generate_private_key( + public_exponent=65537, key_size=2048, backend=backend + ) + + # pretty damn sure that this is not actually accepted by anyone + if cn is None: + cn = "*" + + subject = x509.Name( + [ + x509.NameAttribute(NameOID.ORGANIZATION_NAME, "Dummy Certificate"), + x509.NameAttribute(NameOID.COMMON_NAME, cn), + ] + ) + + backend = default_backend() + cert = ( + x509.CertificateBuilder() + .subject_name(subject) + .issuer_name(subject) + .public_key(pkey.public_key()) + .serial_number(x509.random_serial_number()) + .not_valid_before(dt.now(timezone.utc)) + .not_valid_after(dt.now(timezone.utc) + timedelta(days=365)) + .add_extension(x509.ExtendedKeyUsage([x509.OID_SERVER_AUTH]), critical=False) + .add_extension(x509.SubjectAlternativeName([x509.DNSName(cn)]), critical=False) + .sign(pkey, hashes.SHA256(), backend) + ) + return cert, pkey + + +def make_ssl_devcert( + base_path: str, host: t.Optional[str] = None, cn: t.Optional[str] = None +) -> t.Tuple[str, str]: + """Creates an SSL key for development. This should be used instead of + the ``'adhoc'`` key which generates a new cert on each server start. + It accepts a path for where it should store the key and cert and + either a host or CN. If a host is given it will use the CN + ``*.host/CN=host``. + + For more information see :func:`run_simple`. + + .. versionadded:: 0.9 + + :param base_path: the path to the certificate and key. The extension + ``.crt`` is added for the certificate, ``.key`` is + added for the key. + :param host: the name of the host. This can be used as an alternative + for the `cn`. + :param cn: the `CN` to use. + """ + + if host is not None: + cn = f"*.{host}/CN={host}" + cert, pkey = generate_adhoc_ssl_pair(cn=cn) + + from cryptography.hazmat.primitives import serialization + + cert_file = f"{base_path}.crt" + pkey_file = f"{base_path}.key" + + with open(cert_file, "wb") as f: + f.write(cert.public_bytes(serialization.Encoding.PEM)) + with open(pkey_file, "wb") as f: + f.write( + pkey.private_bytes( + encoding=serialization.Encoding.PEM, + format=serialization.PrivateFormat.TraditionalOpenSSL, + encryption_algorithm=serialization.NoEncryption(), + ) + ) + + return cert_file, pkey_file + + +def generate_adhoc_ssl_context() -> "ssl.SSLContext": + """Generates an adhoc SSL context for the development server.""" + import tempfile + import atexit + + cert, pkey = generate_adhoc_ssl_pair() + + from cryptography.hazmat.primitives import serialization + + cert_handle, cert_file = tempfile.mkstemp() + pkey_handle, pkey_file = tempfile.mkstemp() + atexit.register(os.remove, pkey_file) + atexit.register(os.remove, cert_file) + + os.write(cert_handle, cert.public_bytes(serialization.Encoding.PEM)) + os.write( + pkey_handle, + pkey.private_bytes( + encoding=serialization.Encoding.PEM, + format=serialization.PrivateFormat.TraditionalOpenSSL, + encryption_algorithm=serialization.NoEncryption(), + ), + ) + + os.close(cert_handle) + os.close(pkey_handle) + ctx = load_ssl_context(cert_file, pkey_file) + return ctx + + +def load_ssl_context( + cert_file: str, pkey_file: t.Optional[str] = None, protocol: t.Optional[int] = None +) -> "ssl.SSLContext": + """Loads SSL context from cert/private key files and optional protocol. + Many parameters are directly taken from the API of + :py:class:`ssl.SSLContext`. + + :param cert_file: Path of the certificate to use. + :param pkey_file: Path of the private key to use. If not given, the key + will be obtained from the certificate file. + :param protocol: A ``PROTOCOL`` constant from the :mod:`ssl` module. + Defaults to :data:`ssl.PROTOCOL_TLS_SERVER`. + """ + if protocol is None: + protocol = ssl.PROTOCOL_TLS_SERVER + + ctx = ssl.SSLContext(protocol) + ctx.load_cert_chain(cert_file, pkey_file) + return ctx + + +def is_ssl_error(error: t.Optional[Exception] = None) -> bool: + """Checks if the given error (or the current one) is an SSL error.""" + if error is None: + error = t.cast(Exception, sys.exc_info()[1]) + return isinstance(error, ssl.SSLError) + + +def select_address_family(host: str, port: int) -> socket.AddressFamily: + """Return ``AF_INET4``, ``AF_INET6``, or ``AF_UNIX`` depending on + the host and port.""" + if host.startswith("unix://"): + return socket.AF_UNIX + elif ":" in host and hasattr(socket, "AF_INET6"): + return socket.AF_INET6 + return socket.AF_INET + + +def get_sockaddr( + host: str, port: int, family: socket.AddressFamily +) -> t.Union[t.Tuple[str, int], str]: + """Return a fully qualified socket address that can be passed to + :func:`socket.bind`.""" + if family == af_unix: + return host.split("://", 1)[1] + try: + res = socket.getaddrinfo( + host, port, family, socket.SOCK_STREAM, socket.IPPROTO_TCP + ) + except socket.gaierror: + return host, port + return res[0][4] # type: ignore + + +def get_interface_ip(family: socket.AddressFamily) -> str: + """Get the IP address of an external interface. Used when binding to + 0.0.0.0 or ::1 to show a more useful URL. + + :meta private: + """ + # arbitrary private address + host = "fd31:f903:5ab5:1::1" if family == socket.AF_INET6 else "10.253.155.219" + + with socket.socket(family, socket.SOCK_DGRAM) as s: + try: + s.connect((host, 58162)) + except OSError: + return "::1" if family == socket.AF_INET6 else "127.0.0.1" + + return s.getsockname()[0] # type: ignore + + +class BaseWSGIServer(HTTPServer): + + """Simple single-threaded, single-process WSGI server.""" + + multithread = False + multiprocess = False + request_queue_size = LISTEN_QUEUE + + def __init__( + self, + host: str, + port: int, + app: "WSGIApplication", + handler: t.Optional[t.Type[WSGIRequestHandler]] = None, + passthrough_errors: bool = False, + ssl_context: t.Optional[_TSSLContextArg] = None, + fd: t.Optional[int] = None, + ) -> None: + if handler is None: + handler = WSGIRequestHandler + + self.address_family = select_address_family(host, port) + + if fd is not None: + real_sock = socket.fromfd(fd, self.address_family, socket.SOCK_STREAM) + port = 0 + + server_address = get_sockaddr(host, int(port), self.address_family) + + # remove socket file if it already exists + if self.address_family == af_unix: + server_address = t.cast(str, server_address) + + if os.path.exists(server_address): + os.unlink(server_address) + + super().__init__(server_address, handler) # type: ignore + + self.app = app + self.passthrough_errors = passthrough_errors + self.shutdown_signal = False + self.host = host + self.port = self.socket.getsockname()[1] + + # Patch in the original socket. + if fd is not None: + self.socket.close() + self.socket = real_sock + self.server_address = self.socket.getsockname() + + if ssl_context is not None: + if isinstance(ssl_context, tuple): + ssl_context = load_ssl_context(*ssl_context) + if ssl_context == "adhoc": + ssl_context = generate_adhoc_ssl_context() + + self.socket = ssl_context.wrap_socket(self.socket, server_side=True) + self.ssl_context: t.Optional["ssl.SSLContext"] = ssl_context + else: + self.ssl_context = None + + def log(self, type: str, message: str, *args: t.Any) -> None: + _log(type, message, *args) + + def serve_forever(self, poll_interval: float = 0.5) -> None: + self.shutdown_signal = False + try: + super().serve_forever(poll_interval=poll_interval) + except KeyboardInterrupt: + pass + finally: + self.server_close() + + def handle_error(self, request: t.Any, client_address: t.Tuple[str, int]) -> None: + if self.passthrough_errors: + raise + + return super().handle_error(request, client_address) + + +class ThreadedWSGIServer(socketserver.ThreadingMixIn, BaseWSGIServer): + + """A WSGI server that does threading.""" + + multithread = True + daemon_threads = True + + +class ForkingWSGIServer(ForkingMixIn, BaseWSGIServer): + + """A WSGI server that does forking.""" + + multiprocess = True + + def __init__( + self, + host: str, + port: int, + app: "WSGIApplication", + processes: int = 40, + handler: t.Optional[t.Type[WSGIRequestHandler]] = None, + passthrough_errors: bool = False, + ssl_context: t.Optional[_TSSLContextArg] = None, + fd: t.Optional[int] = None, + ) -> None: + if not can_fork: + raise ValueError("Your platform does not support forking.") + BaseWSGIServer.__init__( + self, host, port, app, handler, passthrough_errors, ssl_context, fd + ) + self.max_children = processes + + +def make_server( + host: str, + port: int, + app: "WSGIApplication", + threaded: bool = False, + processes: int = 1, + request_handler: t.Optional[t.Type[WSGIRequestHandler]] = None, + passthrough_errors: bool = False, + ssl_context: t.Optional[_TSSLContextArg] = None, + fd: t.Optional[int] = None, +) -> BaseWSGIServer: + """Create a new server instance that is either threaded, or forks + or just processes one request after another. + """ + if threaded and processes > 1: + raise ValueError("cannot have a multithreaded and multi process server.") + elif threaded: + return ThreadedWSGIServer( + host, port, app, request_handler, passthrough_errors, ssl_context, fd=fd + ) + elif processes > 1: + return ForkingWSGIServer( + host, + port, + app, + processes, + request_handler, + passthrough_errors, + ssl_context, + fd=fd, + ) + else: + return BaseWSGIServer( + host, port, app, request_handler, passthrough_errors, ssl_context, fd=fd + ) + + +def is_running_from_reloader() -> bool: + """Checks if the application is running from within the Werkzeug + reloader subprocess. + + .. versionadded:: 0.10 + """ + return os.environ.get("WERKZEUG_RUN_MAIN") == "true" + + +def run_simple( + hostname: str, + port: int, + application: "WSGIApplication", + use_reloader: bool = False, + use_debugger: bool = False, + use_evalex: bool = True, + extra_files: t.Optional[t.Iterable[str]] = None, + exclude_patterns: t.Optional[t.Iterable[str]] = None, + reloader_interval: int = 1, + reloader_type: str = "auto", + threaded: bool = False, + processes: int = 1, + request_handler: t.Optional[t.Type[WSGIRequestHandler]] = None, + static_files: t.Optional[t.Dict[str, t.Union[str, t.Tuple[str, str]]]] = None, + passthrough_errors: bool = False, + ssl_context: t.Optional[_TSSLContextArg] = None, +) -> None: + """Start a WSGI application. Optional features include a reloader, + multithreading and fork support. + + This function has a command-line interface too:: + + python -m werkzeug.serving --help + + .. versionchanged:: 2.0 + Added ``exclude_patterns`` parameter. + + .. versionadded:: 0.5 + `static_files` was added to simplify serving of static files as well + as `passthrough_errors`. + + .. versionadded:: 0.6 + support for SSL was added. + + .. versionadded:: 0.8 + Added support for automatically loading a SSL context from certificate + file and private key. + + .. versionadded:: 0.9 + Added command-line interface. + + .. versionadded:: 0.10 + Improved the reloader and added support for changing the backend + through the `reloader_type` parameter. See :ref:`reloader` + for more information. + + .. versionchanged:: 0.15 + Bind to a Unix socket by passing a path that starts with + ``unix://`` as the ``hostname``. + + :param hostname: The host to bind to, for example ``'localhost'``. + If the value is a path that starts with ``unix://`` it will bind + to a Unix socket instead of a TCP socket.. + :param port: The port for the server. eg: ``8080`` + :param application: the WSGI application to execute + :param use_reloader: should the server automatically restart the python + process if modules were changed? + :param use_debugger: should the werkzeug debugging system be used? + :param use_evalex: should the exception evaluation feature be enabled? + :param extra_files: a list of files the reloader should watch + additionally to the modules. For example configuration + files. + :param exclude_patterns: List of :mod:`fnmatch` patterns to ignore + when running the reloader. For example, ignore cache files that + shouldn't reload when updated. + :param reloader_interval: the interval for the reloader in seconds. + :param reloader_type: the type of reloader to use. The default is + auto detection. Valid values are ``'stat'`` and + ``'watchdog'``. See :ref:`reloader` for more + information. + :param threaded: should the process handle each request in a separate + thread? + :param processes: if greater than 1 then handle each request in a new process + up to this maximum number of concurrent processes. + :param request_handler: optional parameter that can be used to replace + the default one. You can use this to replace it + with a different + :class:`~BaseHTTPServer.BaseHTTPRequestHandler` + subclass. + :param static_files: a list or dict of paths for static files. This works + exactly like :class:`SharedDataMiddleware`, it's actually + just wrapping the application in that middleware before + serving. + :param passthrough_errors: set this to `True` to disable the error catching. + This means that the server will die on errors but + it can be useful to hook debuggers in (pdb etc.) + :param ssl_context: an SSL context for the connection. Either an + :class:`ssl.SSLContext`, a tuple in the form + ``(cert_file, pkey_file)``, the string ``'adhoc'`` if + the server should automatically create one, or ``None`` + to disable SSL (which is the default). + """ + if not isinstance(port, int): + raise TypeError("port must be an integer") + if use_debugger: + from .debug import DebuggedApplication + + application = DebuggedApplication(application, use_evalex) + if static_files: + from .middleware.shared_data import SharedDataMiddleware + + application = SharedDataMiddleware(application, static_files) + + def log_startup(sock: socket.socket) -> None: + all_addresses_message = ( + " * Running on all addresses.\n" + " WARNING: This is a development server. Do not use it in" + " a production deployment." + ) + + if sock.family == af_unix: + _log("info", " * Running on %s (Press CTRL+C to quit)", hostname) + else: + if hostname == "0.0.0.0": + _log("warning", all_addresses_message) + display_hostname = get_interface_ip(socket.AF_INET) + elif hostname == "::": + _log("warning", all_addresses_message) + display_hostname = get_interface_ip(socket.AF_INET6) + else: + display_hostname = hostname + + if ":" in display_hostname: + display_hostname = f"[{display_hostname}]" + + _log( + "info", + " * Running on %s://%s:%d/ (Press CTRL+C to quit)", + "http" if ssl_context is None else "https", + display_hostname, + sock.getsockname()[1], + ) + + def inner() -> None: + try: + fd: t.Optional[int] = int(os.environ["WERKZEUG_SERVER_FD"]) + except (LookupError, ValueError): + fd = None + srv = make_server( + hostname, + port, + application, + threaded, + processes, + request_handler, + passthrough_errors, + ssl_context, + fd=fd, + ) + if fd is None: + log_startup(srv.socket) + srv.serve_forever() + + if use_reloader: + # If we're not running already in the subprocess that is the + # reloader we want to open up a socket early to make sure the + # port is actually available. + if not is_running_from_reloader(): + if port == 0 and not can_open_by_fd: + raise ValueError( + "Cannot bind to a random port with enabled " + "reloader if the Python interpreter does " + "not support socket opening by fd." + ) + + # Create and destroy a socket so that any exceptions are + # raised before we spawn a separate Python interpreter and + # lose this ability. + address_family = select_address_family(hostname, port) + server_address = get_sockaddr(hostname, port, address_family) + s = socket.socket(address_family, socket.SOCK_STREAM) + s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) + s.bind(server_address) + s.set_inheritable(True) + + # If we can open the socket by file descriptor, then we can just + # reuse this one and our socket will survive the restarts. + if can_open_by_fd: + os.environ["WERKZEUG_SERVER_FD"] = str(s.fileno()) + s.listen(LISTEN_QUEUE) + log_startup(s) + else: + s.close() + if address_family == af_unix: + server_address = t.cast(str, server_address) + _log("info", "Unlinking %s", server_address) + os.unlink(server_address) + + from ._reloader import run_with_reloader as _rwr + + _rwr( + inner, + extra_files=extra_files, + exclude_patterns=exclude_patterns, + interval=reloader_interval, + reloader_type=reloader_type, + ) + else: + inner() + + +def run_with_reloader(*args: t.Any, **kwargs: t.Any) -> None: + """Run a process with the reloader. This is not a public API, do + not use this function. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. + """ + from ._reloader import run_with_reloader as _rwr + + warnings.warn( + ( + "'run_with_reloader' is a private API, it will no longer be" + " accessible in Werkzeug 2.1. Use 'run_simple' instead." + ), + DeprecationWarning, + stacklevel=2, + ) + _rwr(*args, **kwargs) + + +def main() -> None: + """A simple command-line interface for :py:func:`run_simple`.""" + import argparse + from .utils import import_string + + _log("warning", "This CLI is deprecated and will be removed in version 2.1.") + + parser = argparse.ArgumentParser( + description="Run the given WSGI application with the development server.", + allow_abbrev=False, + ) + parser.add_argument( + "-b", + "--bind", + dest="address", + help="The hostname:port the app should listen on.", + ) + parser.add_argument( + "-d", + "--debug", + action="store_true", + help="Show the interactive debugger for unhandled exceptions.", + ) + parser.add_argument( + "-r", + "--reload", + action="store_true", + help="Reload the process if modules change.", + ) + parser.add_argument( + "application", help="Application to import and serve, in the form module:app." + ) + args = parser.parse_args() + hostname, port = None, None + + if args.address: + hostname, _, port = args.address.partition(":") + + run_simple( + hostname=hostname or "127.0.0.1", + port=int(port or 5000), + application=import_string(args.application), + use_reloader=args.reload, + use_debugger=args.debug, + ) + + +if __name__ == "__main__": + main() diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/test.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/test.py new file mode 100644 index 00000000..09cb7e89 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/test.py @@ -0,0 +1,1326 @@ +import mimetypes +import sys +import typing as t +import warnings +from collections import defaultdict +from datetime import datetime +from datetime import timedelta +from http.cookiejar import CookieJar +from io import BytesIO +from itertools import chain +from random import random +from tempfile import TemporaryFile +from time import time +from urllib.request import Request as _UrllibRequest + +from ._internal import _get_environ +from ._internal import _make_encode_wrapper +from ._internal import _wsgi_decoding_dance +from ._internal import _wsgi_encoding_dance +from .datastructures import Authorization +from .datastructures import CallbackDict +from .datastructures import CombinedMultiDict +from .datastructures import EnvironHeaders +from .datastructures import FileMultiDict +from .datastructures import Headers +from .datastructures import MultiDict +from .http import dump_cookie +from .http import dump_options_header +from .http import parse_options_header +from .sansio.multipart import Data +from .sansio.multipart import Epilogue +from .sansio.multipart import Field +from .sansio.multipart import File +from .sansio.multipart import MultipartEncoder +from .sansio.multipart import Preamble +from .urls import iri_to_uri +from .urls import url_encode +from .urls import url_fix +from .urls import url_parse +from .urls import url_unparse +from .urls import url_unquote +from .utils import get_content_type +from .wrappers.request import Request +from .wrappers.response import Response +from .wsgi import ClosingIterator +from .wsgi import get_current_url + +if t.TYPE_CHECKING: + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +def stream_encode_multipart( + data: t.Mapping[str, t.Any], + use_tempfile: bool = True, + threshold: int = 1024 * 500, + boundary: t.Optional[str] = None, + charset: str = "utf-8", +) -> t.Tuple[t.IO[bytes], int, str]: + """Encode a dict of values (either strings or file descriptors or + :class:`FileStorage` objects.) into a multipart encoded string stored + in a file descriptor. + """ + if boundary is None: + boundary = f"---------------WerkzeugFormPart_{time()}{random()}" + + stream: t.IO[bytes] = BytesIO() + total_length = 0 + on_disk = False + + if use_tempfile: + + def write_binary(s: bytes) -> int: + nonlocal stream, total_length, on_disk + + if on_disk: + return stream.write(s) + else: + length = len(s) + + if length + total_length <= threshold: + stream.write(s) + else: + new_stream = t.cast(t.IO[bytes], TemporaryFile("wb+")) + new_stream.write(stream.getvalue()) # type: ignore + new_stream.write(s) + stream = new_stream + on_disk = True + + total_length += length + return length + + else: + write_binary = stream.write + + encoder = MultipartEncoder(boundary.encode()) + write_binary(encoder.send_event(Preamble(data=b""))) + for key, value in _iter_data(data): + reader = getattr(value, "read", None) + if reader is not None: + filename = getattr(value, "filename", getattr(value, "name", None)) + content_type = getattr(value, "content_type", None) + if content_type is None: + content_type = ( + filename + and mimetypes.guess_type(filename)[0] + or "application/octet-stream" + ) + headers = Headers([("Content-Type", content_type)]) + if filename is None: + write_binary(encoder.send_event(Field(name=key, headers=headers))) + else: + write_binary( + encoder.send_event( + File(name=key, filename=filename, headers=headers) + ) + ) + while True: + chunk = reader(16384) + + if not chunk: + break + + write_binary(encoder.send_event(Data(data=chunk, more_data=True))) + else: + if not isinstance(value, str): + value = str(value) + write_binary(encoder.send_event(Field(name=key, headers=Headers()))) + write_binary( + encoder.send_event(Data(data=value.encode(charset), more_data=False)) + ) + + write_binary(encoder.send_event(Epilogue(data=b""))) + + length = stream.tell() + stream.seek(0) + return stream, length, boundary + + +def encode_multipart( + values: t.Mapping[str, t.Any], + boundary: t.Optional[str] = None, + charset: str = "utf-8", +) -> t.Tuple[str, bytes]: + """Like `stream_encode_multipart` but returns a tuple in the form + (``boundary``, ``data``) where data is bytes. + """ + stream, length, boundary = stream_encode_multipart( + values, use_tempfile=False, boundary=boundary, charset=charset + ) + return boundary, stream.read() + + +class _TestCookieHeaders: + """A headers adapter for cookielib""" + + def __init__(self, headers: t.Union[Headers, t.List[t.Tuple[str, str]]]) -> None: + self.headers = headers + + def getheaders(self, name: str) -> t.Iterable[str]: + headers = [] + name = name.lower() + for k, v in self.headers: + if k.lower() == name: + headers.append(v) + return headers + + def get_all( + self, name: str, default: t.Optional[t.Iterable[str]] = None + ) -> t.Iterable[str]: + headers = self.getheaders(name) + + if not headers: + return default # type: ignore + + return headers + + +class _TestCookieResponse: + """Something that looks like a httplib.HTTPResponse, but is actually just an + adapter for our test responses to make them available for cookielib. + """ + + def __init__(self, headers: t.Union[Headers, t.List[t.Tuple[str, str]]]) -> None: + self.headers = _TestCookieHeaders(headers) + + def info(self) -> _TestCookieHeaders: + return self.headers + + +class _TestCookieJar(CookieJar): + """A cookielib.CookieJar modified to inject and read cookie headers from + and to wsgi environments, and wsgi application responses. + """ + + def inject_wsgi(self, environ: "WSGIEnvironment") -> None: + """Inject the cookies as client headers into the server's wsgi + environment. + """ + cvals = [f"{c.name}={c.value}" for c in self] + + if cvals: + environ["HTTP_COOKIE"] = "; ".join(cvals) + else: + environ.pop("HTTP_COOKIE", None) + + def extract_wsgi( + self, + environ: "WSGIEnvironment", + headers: t.Union[Headers, t.List[t.Tuple[str, str]]], + ) -> None: + """Extract the server's set-cookie headers as cookies into the + cookie jar. + """ + self.extract_cookies( + _TestCookieResponse(headers), # type: ignore + _UrllibRequest(get_current_url(environ)), + ) + + +def _iter_data(data: t.Mapping[str, t.Any]) -> t.Iterator[t.Tuple[str, t.Any]]: + """Iterate over a mapping that might have a list of values, yielding + all key, value pairs. Almost like iter_multi_items but only allows + lists, not tuples, of values so tuples can be used for files. + """ + if isinstance(data, MultiDict): + yield from data.items(multi=True) + else: + for key, value in data.items(): + if isinstance(value, list): + for v in value: + yield key, v + else: + yield key, value + + +_TAnyMultiDict = t.TypeVar("_TAnyMultiDict", bound=MultiDict) + + +class EnvironBuilder: + """This class can be used to conveniently create a WSGI environment + for testing purposes. It can be used to quickly create WSGI environments + or request objects from arbitrary data. + + The signature of this class is also used in some other places as of + Werkzeug 0.5 (:func:`create_environ`, :meth:`Response.from_values`, + :meth:`Client.open`). Because of this most of the functionality is + available through the constructor alone. + + Files and regular form data can be manipulated independently of each + other with the :attr:`form` and :attr:`files` attributes, but are + passed with the same argument to the constructor: `data`. + + `data` can be any of these values: + + - a `str` or `bytes` object: The object is converted into an + :attr:`input_stream`, the :attr:`content_length` is set and you have to + provide a :attr:`content_type`. + - a `dict` or :class:`MultiDict`: The keys have to be strings. The values + have to be either any of the following objects, or a list of any of the + following objects: + + - a :class:`file`-like object: These are converted into + :class:`FileStorage` objects automatically. + - a `tuple`: The :meth:`~FileMultiDict.add_file` method is called + with the key and the unpacked `tuple` items as positional + arguments. + - a `str`: The string is set as form data for the associated key. + - a file-like object: The object content is loaded in memory and then + handled like a regular `str` or a `bytes`. + + :param path: the path of the request. In the WSGI environment this will + end up as `PATH_INFO`. If the `query_string` is not defined + and there is a question mark in the `path` everything after + it is used as query string. + :param base_url: the base URL is a URL that is used to extract the WSGI + URL scheme, host (server name + server port) and the + script root (`SCRIPT_NAME`). + :param query_string: an optional string or dict with URL parameters. + :param method: the HTTP method to use, defaults to `GET`. + :param input_stream: an optional input stream. Do not specify this and + `data`. As soon as an input stream is set you can't + modify :attr:`args` and :attr:`files` unless you + set the :attr:`input_stream` to `None` again. + :param content_type: The content type for the request. As of 0.5 you + don't have to provide this when specifying files + and form data via `data`. + :param content_length: The content length for the request. You don't + have to specify this when providing data via + `data`. + :param errors_stream: an optional error stream that is used for + `wsgi.errors`. Defaults to :data:`stderr`. + :param multithread: controls `wsgi.multithread`. Defaults to `False`. + :param multiprocess: controls `wsgi.multiprocess`. Defaults to `False`. + :param run_once: controls `wsgi.run_once`. Defaults to `False`. + :param headers: an optional list or :class:`Headers` object of headers. + :param data: a string or dict of form data or a file-object. + See explanation above. + :param json: An object to be serialized and assigned to ``data``. + Defaults the content type to ``"application/json"``. + Serialized with the function assigned to :attr:`json_dumps`. + :param environ_base: an optional dict of environment defaults. + :param environ_overrides: an optional dict of environment overrides. + :param charset: the charset used to encode string data. + :param auth: An authorization object to use for the + ``Authorization`` header value. A ``(username, password)`` tuple + is a shortcut for ``Basic`` authorization. + + .. versionchanged:: 2.0 + ``REQUEST_URI`` and ``RAW_URI`` is the full raw URI including + the query string, not only the path. + + .. versionchanged:: 2.0 + The default :attr:`request_class` is ``Request`` instead of + ``BaseRequest``. + + .. versionadded:: 2.0 + Added the ``auth`` parameter. + + .. versionadded:: 0.15 + The ``json`` param and :meth:`json_dumps` method. + + .. versionadded:: 0.15 + The environ has keys ``REQUEST_URI`` and ``RAW_URI`` containing + the path before perecent-decoding. This is not part of the WSGI + PEP, but many WSGI servers include it. + + .. versionchanged:: 0.6 + ``path`` and ``base_url`` can now be unicode strings that are + encoded with :func:`iri_to_uri`. + """ + + #: the server protocol to use. defaults to HTTP/1.1 + server_protocol = "HTTP/1.1" + + #: the wsgi version to use. defaults to (1, 0) + wsgi_version = (1, 0) + + #: The default request class used by :meth:`get_request`. + request_class = Request + + import json + + #: The serialization function used when ``json`` is passed. + json_dumps = staticmethod(json.dumps) + del json + + _args: t.Optional[MultiDict] + _query_string: t.Optional[str] + _input_stream: t.Optional[t.IO[bytes]] + _form: t.Optional[MultiDict] + _files: t.Optional[FileMultiDict] + + def __init__( + self, + path: str = "/", + base_url: t.Optional[str] = None, + query_string: t.Optional[t.Union[t.Mapping[str, str], str]] = None, + method: str = "GET", + input_stream: t.Optional[t.IO[bytes]] = None, + content_type: t.Optional[str] = None, + content_length: t.Optional[int] = None, + errors_stream: t.Optional[t.IO[str]] = None, + multithread: bool = False, + multiprocess: bool = False, + run_once: bool = False, + headers: t.Optional[t.Union[Headers, t.Iterable[t.Tuple[str, str]]]] = None, + data: t.Optional[ + t.Union[t.IO[bytes], str, bytes, t.Mapping[str, t.Any]] + ] = None, + environ_base: t.Optional[t.Mapping[str, t.Any]] = None, + environ_overrides: t.Optional[t.Mapping[str, t.Any]] = None, + charset: str = "utf-8", + mimetype: t.Optional[str] = None, + json: t.Optional[t.Mapping[str, t.Any]] = None, + auth: t.Optional[t.Union[Authorization, t.Tuple[str, str]]] = None, + ) -> None: + path_s = _make_encode_wrapper(path) + if query_string is not None and path_s("?") in path: + raise ValueError("Query string is defined in the path and as an argument") + request_uri = url_parse(path) + if query_string is None and path_s("?") in path: + query_string = request_uri.query + self.charset = charset + self.path = iri_to_uri(request_uri.path) + self.request_uri = path + if base_url is not None: + base_url = url_fix(iri_to_uri(base_url, charset), charset) + self.base_url = base_url # type: ignore + if isinstance(query_string, (bytes, str)): + self.query_string = query_string + else: + if query_string is None: + query_string = MultiDict() + elif not isinstance(query_string, MultiDict): + query_string = MultiDict(query_string) + self.args = query_string + self.method = method + if headers is None: + headers = Headers() + elif not isinstance(headers, Headers): + headers = Headers(headers) + self.headers = headers + if content_type is not None: + self.content_type = content_type + if errors_stream is None: + errors_stream = sys.stderr + self.errors_stream = errors_stream + self.multithread = multithread + self.multiprocess = multiprocess + self.run_once = run_once + self.environ_base = environ_base + self.environ_overrides = environ_overrides + self.input_stream = input_stream + self.content_length = content_length + self.closed = False + + if auth is not None: + if isinstance(auth, tuple): + auth = Authorization( + "basic", {"username": auth[0], "password": auth[1]} + ) + + self.headers.set("Authorization", auth.to_header()) + + if json is not None: + if data is not None: + raise TypeError("can't provide both json and data") + + data = self.json_dumps(json) + + if self.content_type is None: + self.content_type = "application/json" + + if data: + if input_stream is not None: + raise TypeError("can't provide input stream and data") + if hasattr(data, "read"): + data = data.read() # type: ignore + if isinstance(data, str): + data = data.encode(self.charset) + if isinstance(data, bytes): + self.input_stream = BytesIO(data) + if self.content_length is None: + self.content_length = len(data) + else: + for key, value in _iter_data(data): # type: ignore + if isinstance(value, (tuple, dict)) or hasattr(value, "read"): + self._add_file_from_data(key, value) + else: + self.form.setlistdefault(key).append(value) + + if mimetype is not None: + self.mimetype = mimetype + + @classmethod + def from_environ( + cls, environ: "WSGIEnvironment", **kwargs: t.Any + ) -> "EnvironBuilder": + """Turn an environ dict back into a builder. Any extra kwargs + override the args extracted from the environ. + + .. versionchanged:: 2.0 + Path and query values are passed through the WSGI decoding + dance to avoid double encoding. + + .. versionadded:: 0.15 + """ + headers = Headers(EnvironHeaders(environ)) + out = { + "path": _wsgi_decoding_dance(environ["PATH_INFO"]), + "base_url": cls._make_base_url( + environ["wsgi.url_scheme"], + headers.pop("Host"), + _wsgi_decoding_dance(environ["SCRIPT_NAME"]), + ), + "query_string": _wsgi_decoding_dance(environ["QUERY_STRING"]), + "method": environ["REQUEST_METHOD"], + "input_stream": environ["wsgi.input"], + "content_type": headers.pop("Content-Type", None), + "content_length": headers.pop("Content-Length", None), + "errors_stream": environ["wsgi.errors"], + "multithread": environ["wsgi.multithread"], + "multiprocess": environ["wsgi.multiprocess"], + "run_once": environ["wsgi.run_once"], + "headers": headers, + } + out.update(kwargs) + return cls(**out) + + def _add_file_from_data( + self, + key: str, + value: t.Union[ + t.IO[bytes], t.Tuple[t.IO[bytes], str], t.Tuple[t.IO[bytes], str, str] + ], + ) -> None: + """Called in the EnvironBuilder to add files from the data dict.""" + if isinstance(value, tuple): + self.files.add_file(key, *value) + else: + self.files.add_file(key, value) + + @staticmethod + def _make_base_url(scheme: str, host: str, script_root: str) -> str: + return url_unparse((scheme, host, script_root, "", "")).rstrip("/") + "/" + + @property + def base_url(self) -> str: + """The base URL is used to extract the URL scheme, host name, + port, and root path. + """ + return self._make_base_url(self.url_scheme, self.host, self.script_root) + + @base_url.setter + def base_url(self, value: t.Optional[str]) -> None: + if value is None: + scheme = "http" + netloc = "localhost" + script_root = "" + else: + scheme, netloc, script_root, qs, anchor = url_parse(value) + if qs or anchor: + raise ValueError("base url must not contain a query string or fragment") + self.script_root = script_root.rstrip("/") + self.host = netloc + self.url_scheme = scheme + + @property + def content_type(self) -> t.Optional[str]: + """The content type for the request. Reflected from and to + the :attr:`headers`. Do not set if you set :attr:`files` or + :attr:`form` for auto detection. + """ + ct = self.headers.get("Content-Type") + if ct is None and not self._input_stream: + if self._files: + return "multipart/form-data" + if self._form: + return "application/x-www-form-urlencoded" + return None + return ct + + @content_type.setter + def content_type(self, value: t.Optional[str]) -> None: + if value is None: + self.headers.pop("Content-Type", None) + else: + self.headers["Content-Type"] = value + + @property + def mimetype(self) -> t.Optional[str]: + """The mimetype (content type without charset etc.) + + .. versionadded:: 0.14 + """ + ct = self.content_type + return ct.split(";")[0].strip() if ct else None + + @mimetype.setter + def mimetype(self, value: str) -> None: + self.content_type = get_content_type(value, self.charset) + + @property + def mimetype_params(self) -> t.Mapping[str, str]: + """The mimetype parameters as dict. For example if the + content type is ``text/html; charset=utf-8`` the params would be + ``{'charset': 'utf-8'}``. + + .. versionadded:: 0.14 + """ + + def on_update(d: CallbackDict) -> None: + self.headers["Content-Type"] = dump_options_header(self.mimetype, d) + + d = parse_options_header(self.headers.get("content-type", ""))[1] + return CallbackDict(d, on_update) + + @property + def content_length(self) -> t.Optional[int]: + """The content length as integer. Reflected from and to the + :attr:`headers`. Do not set if you set :attr:`files` or + :attr:`form` for auto detection. + """ + return self.headers.get("Content-Length", type=int) + + @content_length.setter + def content_length(self, value: t.Optional[int]) -> None: + if value is None: + self.headers.pop("Content-Length", None) + else: + self.headers["Content-Length"] = str(value) + + def _get_form(self, name: str, storage: t.Type[_TAnyMultiDict]) -> _TAnyMultiDict: + """Common behavior for getting the :attr:`form` and + :attr:`files` properties. + + :param name: Name of the internal cached attribute. + :param storage: Storage class used for the data. + """ + if self.input_stream is not None: + raise AttributeError("an input stream is defined") + + rv = getattr(self, name) + + if rv is None: + rv = storage() + setattr(self, name, rv) + + return rv # type: ignore + + def _set_form(self, name: str, value: MultiDict) -> None: + """Common behavior for setting the :attr:`form` and + :attr:`files` properties. + + :param name: Name of the internal cached attribute. + :param value: Value to assign to the attribute. + """ + self._input_stream = None + setattr(self, name, value) + + @property + def form(self) -> MultiDict: + """A :class:`MultiDict` of form values.""" + return self._get_form("_form", MultiDict) + + @form.setter + def form(self, value: MultiDict) -> None: + self._set_form("_form", value) + + @property + def files(self) -> FileMultiDict: + """A :class:`FileMultiDict` of uploaded files. Use + :meth:`~FileMultiDict.add_file` to add new files. + """ + return self._get_form("_files", FileMultiDict) + + @files.setter + def files(self, value: FileMultiDict) -> None: + self._set_form("_files", value) + + @property + def input_stream(self) -> t.Optional[t.IO[bytes]]: + """An optional input stream. This is mutually exclusive with + setting :attr:`form` and :attr:`files`, setting it will clear + those. Do not provide this if the method is not ``POST`` or + another method that has a body. + """ + return self._input_stream + + @input_stream.setter + def input_stream(self, value: t.Optional[t.IO[bytes]]) -> None: + self._input_stream = value + self._form = None + self._files = None + + @property + def query_string(self) -> str: + """The query string. If you set this to a string + :attr:`args` will no longer be available. + """ + if self._query_string is None: + if self._args is not None: + return url_encode(self._args, charset=self.charset) + return "" + return self._query_string + + @query_string.setter + def query_string(self, value: t.Optional[str]) -> None: + self._query_string = value + self._args = None + + @property + def args(self) -> MultiDict: + """The URL arguments as :class:`MultiDict`.""" + if self._query_string is not None: + raise AttributeError("a query string is defined") + if self._args is None: + self._args = MultiDict() + return self._args + + @args.setter + def args(self, value: t.Optional[MultiDict]) -> None: + self._query_string = None + self._args = value + + @property + def server_name(self) -> str: + """The server name (read-only, use :attr:`host` to set)""" + return self.host.split(":", 1)[0] + + @property + def server_port(self) -> int: + """The server port as integer (read-only, use :attr:`host` to set)""" + pieces = self.host.split(":", 1) + if len(pieces) == 2 and pieces[1].isdigit(): + return int(pieces[1]) + if self.url_scheme == "https": + return 443 + return 80 + + def __del__(self) -> None: + try: + self.close() + except Exception: + pass + + def close(self) -> None: + """Closes all files. If you put real :class:`file` objects into the + :attr:`files` dict you can call this method to automatically close + them all in one go. + """ + if self.closed: + return + try: + files = self.files.values() + except AttributeError: + files = () # type: ignore + for f in files: + try: + f.close() + except Exception: + pass + self.closed = True + + def get_environ(self) -> "WSGIEnvironment": + """Return the built environ. + + .. versionchanged:: 0.15 + The content type and length headers are set based on + input stream detection. Previously this only set the WSGI + keys. + """ + input_stream = self.input_stream + content_length = self.content_length + + mimetype = self.mimetype + content_type = self.content_type + + if input_stream is not None: + start_pos = input_stream.tell() + input_stream.seek(0, 2) + end_pos = input_stream.tell() + input_stream.seek(start_pos) + content_length = end_pos - start_pos + elif mimetype == "multipart/form-data": + input_stream, content_length, boundary = stream_encode_multipart( + CombinedMultiDict([self.form, self.files]), charset=self.charset + ) + content_type = f'{mimetype}; boundary="{boundary}"' + elif mimetype == "application/x-www-form-urlencoded": + form_encoded = url_encode(self.form, charset=self.charset).encode("ascii") + content_length = len(form_encoded) + input_stream = BytesIO(form_encoded) + else: + input_stream = BytesIO() + + result: "WSGIEnvironment" = {} + if self.environ_base: + result.update(self.environ_base) + + def _path_encode(x: str) -> str: + return _wsgi_encoding_dance(url_unquote(x, self.charset), self.charset) + + raw_uri = _wsgi_encoding_dance(self.request_uri, self.charset) + result.update( + { + "REQUEST_METHOD": self.method, + "SCRIPT_NAME": _path_encode(self.script_root), + "PATH_INFO": _path_encode(self.path), + "QUERY_STRING": _wsgi_encoding_dance(self.query_string, self.charset), + # Non-standard, added by mod_wsgi, uWSGI + "REQUEST_URI": raw_uri, + # Non-standard, added by gunicorn + "RAW_URI": raw_uri, + "SERVER_NAME": self.server_name, + "SERVER_PORT": str(self.server_port), + "HTTP_HOST": self.host, + "SERVER_PROTOCOL": self.server_protocol, + "wsgi.version": self.wsgi_version, + "wsgi.url_scheme": self.url_scheme, + "wsgi.input": input_stream, + "wsgi.errors": self.errors_stream, + "wsgi.multithread": self.multithread, + "wsgi.multiprocess": self.multiprocess, + "wsgi.run_once": self.run_once, + } + ) + + headers = self.headers.copy() + + if content_type is not None: + result["CONTENT_TYPE"] = content_type + headers.set("Content-Type", content_type) + + if content_length is not None: + result["CONTENT_LENGTH"] = str(content_length) + headers.set("Content-Length", content_length) + + combined_headers = defaultdict(list) + + for key, value in headers.to_wsgi_list(): + combined_headers[f"HTTP_{key.upper().replace('-', '_')}"].append(value) + + for key, values in combined_headers.items(): + result[key] = ", ".join(values) + + if self.environ_overrides: + result.update(self.environ_overrides) + + return result + + def get_request(self, cls: t.Optional[t.Type[Request]] = None) -> Request: + """Returns a request with the data. If the request class is not + specified :attr:`request_class` is used. + + :param cls: The request wrapper to use. + """ + if cls is None: + cls = self.request_class + + return cls(self.get_environ()) + + +class ClientRedirectError(Exception): + """If a redirect loop is detected when using follow_redirects=True with + the :cls:`Client`, then this exception is raised. + """ + + +class Client: + """This class allows you to send requests to a wrapped application. + + The use_cookies parameter indicates whether cookies should be stored and + sent for subsequent requests. This is True by default, but passing False + will disable this behaviour. + + If you want to request some subdomain of your application you may set + `allow_subdomain_redirects` to `True` as if not no external redirects + are allowed. + + .. versionchanged:: 2.0 + ``response_wrapper`` is always a subclass of + :class:``TestResponse``. + + .. versionchanged:: 0.5 + Added the ``use_cookies`` parameter. + """ + + def __init__( + self, + application: "WSGIApplication", + response_wrapper: t.Optional[t.Type["Response"]] = None, + use_cookies: bool = True, + allow_subdomain_redirects: bool = False, + ) -> None: + self.application = application + + if response_wrapper in {None, Response}: + response_wrapper = TestResponse + elif not isinstance(response_wrapper, TestResponse): + response_wrapper = type( + "WrapperTestResponse", + (TestResponse, response_wrapper), # type: ignore + {}, + ) + + self.response_wrapper = t.cast(t.Type["TestResponse"], response_wrapper) + + if use_cookies: + self.cookie_jar: t.Optional[_TestCookieJar] = _TestCookieJar() + else: + self.cookie_jar = None + + self.allow_subdomain_redirects = allow_subdomain_redirects + + def set_cookie( + self, + server_name: str, + key: str, + value: str = "", + max_age: t.Optional[t.Union[timedelta, int]] = None, + expires: t.Optional[t.Union[str, datetime, int, float]] = None, + path: str = "/", + domain: t.Optional[str] = None, + secure: bool = False, + httponly: bool = False, + samesite: t.Optional[str] = None, + charset: str = "utf-8", + ) -> None: + """Sets a cookie in the client's cookie jar. The server name + is required and has to match the one that is also passed to + the open call. + """ + assert self.cookie_jar is not None, "cookies disabled" + header = dump_cookie( + key, + value, + max_age, + expires, + path, + domain, + secure, + httponly, + charset, + samesite=samesite, + ) + environ = create_environ(path, base_url=f"http://{server_name}") + headers = [("Set-Cookie", header)] + self.cookie_jar.extract_wsgi(environ, headers) + + def delete_cookie( + self, + server_name: str, + key: str, + path: str = "/", + domain: t.Optional[str] = None, + secure: bool = False, + httponly: bool = False, + samesite: t.Optional[str] = None, + ) -> None: + """Deletes a cookie in the test client.""" + self.set_cookie( + server_name, + key, + expires=0, + max_age=0, + path=path, + domain=domain, + secure=secure, + httponly=httponly, + samesite=samesite, + ) + + def run_wsgi_app( + self, environ: "WSGIEnvironment", buffered: bool = False + ) -> t.Tuple[t.Iterable[bytes], str, Headers]: + """Runs the wrapped WSGI app with the given environment. + + :meta private: + """ + if self.cookie_jar is not None: + self.cookie_jar.inject_wsgi(environ) + + rv = run_wsgi_app(self.application, environ, buffered=buffered) + + if self.cookie_jar is not None: + self.cookie_jar.extract_wsgi(environ, rv[2]) + + return rv + + def resolve_redirect( + self, response: "TestResponse", buffered: bool = False + ) -> "TestResponse": + """Perform a new request to the location given by the redirect + response to the previous request. + + :meta private: + """ + scheme, netloc, path, qs, anchor = url_parse(response.location) + builder = EnvironBuilder.from_environ(response.request.environ, query_string=qs) + + to_name_parts = netloc.split(":", 1)[0].split(".") + from_name_parts = builder.server_name.split(".") + + if to_name_parts != [""]: + # The new location has a host, use it for the base URL. + builder.url_scheme = scheme + builder.host = netloc + else: + # A local redirect with autocorrect_location_header=False + # doesn't have a host, so use the request's host. + to_name_parts = from_name_parts + + # Explain why a redirect to a different server name won't be followed. + if to_name_parts != from_name_parts: + if to_name_parts[-len(from_name_parts) :] == from_name_parts: + if not self.allow_subdomain_redirects: + raise RuntimeError("Following subdomain redirects is not enabled.") + else: + raise RuntimeError("Following external redirects is not supported.") + + path_parts = path.split("/") + root_parts = builder.script_root.split("/") + + if path_parts[: len(root_parts)] == root_parts: + # Strip the script root from the path. + builder.path = path[len(builder.script_root) :] + else: + # The new location is not under the script root, so use the + # whole path and clear the previous root. + builder.path = path + builder.script_root = "" + + # Only 307 and 308 preserve all of the original request. + if response.status_code not in {307, 308}: + # HEAD is preserved, everything else becomes GET. + if builder.method != "HEAD": + builder.method = "GET" + + # Clear the body and the headers that describe it. + + if builder.input_stream is not None: + builder.input_stream.close() + builder.input_stream = None + + builder.content_type = None + builder.content_length = None + builder.headers.pop("Transfer-Encoding", None) + + return self.open(builder, buffered=buffered) + + def open( + self, + *args: t.Any, + as_tuple: bool = False, + buffered: bool = False, + follow_redirects: bool = False, + **kwargs: t.Any, + ) -> "TestResponse": + """Generate an environ dict from the given arguments, make a + request to the application using it, and return the response. + + :param args: Passed to :class:`EnvironBuilder` to create the + environ for the request. If a single arg is passed, it can + be an existing :class:`EnvironBuilder` or an environ dict. + :param buffered: Convert the iterator returned by the app into + a list. If the iterator has a ``close()`` method, it is + called automatically. + :param follow_redirects: Make additional requests to follow HTTP + redirects until a non-redirect status is returned. + :attr:`TestResponse.history` lists the intermediate + responses. + + .. versionchanged:: 2.0 + ``as_tuple`` is deprecated and will be removed in Werkzeug + 2.1. Use :attr:`TestResponse.request` and + ``request.environ`` instead. + + .. versionchanged:: 2.0 + The request input stream is closed when calling + ``response.close()``. Input streams for redirects are + automatically closed. + + .. versionchanged:: 0.5 + If a dict is provided as file in the dict for the ``data`` + parameter the content type has to be called ``content_type`` + instead of ``mimetype``. This change was made for + consistency with :class:`werkzeug.FileWrapper`. + + .. versionchanged:: 0.5 + Added the ``follow_redirects`` parameter. + """ + request: t.Optional["Request"] = None + + if not kwargs and len(args) == 1: + arg = args[0] + + if isinstance(arg, EnvironBuilder): + request = arg.get_request() + elif isinstance(arg, dict): + request = EnvironBuilder.from_environ(arg).get_request() + elif isinstance(arg, Request): + request = arg + + if request is None: + builder = EnvironBuilder(*args, **kwargs) + + try: + request = builder.get_request() + finally: + builder.close() + + response = self.run_wsgi_app(request.environ, buffered=buffered) + response = self.response_wrapper(*response, request=request) + + redirects = set() + history: t.List["TestResponse"] = [] + + while follow_redirects and response.status_code in { + 301, + 302, + 303, + 305, + 307, + 308, + }: + # Exhaust intermediate response bodies to ensure middleware + # that returns an iterator runs any cleanup code. + if not buffered: + response.make_sequence() + response.close() + + new_redirect_entry = (response.location, response.status_code) + + if new_redirect_entry in redirects: + raise ClientRedirectError( + f"Loop detected: A {response.status_code} redirect" + f" to {response.location} was already made." + ) + + redirects.add(new_redirect_entry) + response.history = tuple(history) + history.append(response) + response = self.resolve_redirect(response, buffered=buffered) + else: + # This is the final request after redirects, or not + # following redirects. + response.history = tuple(history) + # Close the input stream when closing the response, in case + # the input is an open temporary file. + response.call_on_close(request.input_stream.close) + + if as_tuple: + warnings.warn( + "'as_tuple' is deprecated and will be removed in" + " Werkzeug 2.1. Access 'response.request.environ'" + " instead.", + DeprecationWarning, + stacklevel=2, + ) + return request.environ, response # type: ignore + + return response + + def get(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``GET``.""" + kw["method"] = "GET" + return self.open(*args, **kw) + + def post(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``POST``.""" + kw["method"] = "POST" + return self.open(*args, **kw) + + def put(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``PUT``.""" + kw["method"] = "PUT" + return self.open(*args, **kw) + + def delete(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``DELETE``.""" + kw["method"] = "DELETE" + return self.open(*args, **kw) + + def patch(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``PATCH``.""" + kw["method"] = "PATCH" + return self.open(*args, **kw) + + def options(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``OPTIONS``.""" + kw["method"] = "OPTIONS" + return self.open(*args, **kw) + + def head(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``HEAD``.""" + kw["method"] = "HEAD" + return self.open(*args, **kw) + + def trace(self, *args: t.Any, **kw: t.Any) -> "TestResponse": + """Call :meth:`open` with ``method`` set to ``TRACE``.""" + kw["method"] = "TRACE" + return self.open(*args, **kw) + + def __repr__(self) -> str: + return f"<{type(self).__name__} {self.application!r}>" + + +def create_environ(*args: t.Any, **kwargs: t.Any) -> "WSGIEnvironment": + """Create a new WSGI environ dict based on the values passed. The first + parameter should be the path of the request which defaults to '/'. The + second one can either be an absolute path (in that case the host is + localhost:80) or a full path to the request with scheme, netloc port and + the path to the script. + + This accepts the same arguments as the :class:`EnvironBuilder` + constructor. + + .. versionchanged:: 0.5 + This function is now a thin wrapper over :class:`EnvironBuilder` which + was added in 0.5. The `headers`, `environ_base`, `environ_overrides` + and `charset` parameters were added. + """ + builder = EnvironBuilder(*args, **kwargs) + + try: + return builder.get_environ() + finally: + builder.close() + + +def run_wsgi_app( + app: "WSGIApplication", environ: "WSGIEnvironment", buffered: bool = False +) -> t.Tuple[t.Iterable[bytes], str, Headers]: + """Return a tuple in the form (app_iter, status, headers) of the + application output. This works best if you pass it an application that + returns an iterator all the time. + + Sometimes applications may use the `write()` callable returned + by the `start_response` function. This tries to resolve such edge + cases automatically. But if you don't get the expected output you + should set `buffered` to `True` which enforces buffering. + + If passed an invalid WSGI application the behavior of this function is + undefined. Never pass non-conforming WSGI applications to this function. + + :param app: the application to execute. + :param buffered: set to `True` to enforce buffering. + :return: tuple in the form ``(app_iter, status, headers)`` + """ + # Copy environ to ensure any mutations by the app (ProxyFix, for + # example) don't affect subsequent requests (such as redirects). + environ = _get_environ(environ).copy() + status: str + response: t.Optional[t.Tuple[str, t.List[t.Tuple[str, str]]]] = None + buffer: t.List[bytes] = [] + + def start_response(status, headers, exc_info=None): # type: ignore + nonlocal response + + if exc_info: + try: + raise exc_info[1].with_traceback(exc_info[2]) + finally: + exc_info = None + + response = (status, headers) + return buffer.append + + app_rv = app(environ, start_response) + close_func = getattr(app_rv, "close", None) + app_iter: t.Iterable[bytes] = iter(app_rv) + + # when buffering we emit the close call early and convert the + # application iterator into a regular list + if buffered: + try: + app_iter = list(app_iter) + finally: + if close_func is not None: + close_func() + + # otherwise we iterate the application iter until we have a response, chain + # the already received data with the already collected data and wrap it in + # a new `ClosingIterator` if we need to restore a `close` callable from the + # original return value. + else: + for item in app_iter: + buffer.append(item) + + if response is not None: + break + + if buffer: + app_iter = chain(buffer, app_iter) + + if close_func is not None and app_iter is not app_rv: + app_iter = ClosingIterator(app_iter, close_func) + + status, headers = response # type: ignore + return app_iter, status, Headers(headers) + + +class TestResponse(Response): + """:class:`~werkzeug.wrappers.Response` subclass that provides extra + information about requests made with the test :class:`Client`. + + Test client requests will always return an instance of this class. + If a custom response class is passed to the client, it is + subclassed along with this to support test information. + + If the test request included large files, or if the application is + serving a file, call :meth:`close` to close any open files and + prevent Python showing a ``ResourceWarning``. + """ + + request: Request + """A request object with the environ used to make the request that + resulted in this response. + """ + + history: t.Tuple["TestResponse", ...] + """A list of intermediate responses. Populated when the test request + is made with ``follow_redirects`` enabled. + """ + + def __init__( + self, + response: t.Iterable[bytes], + status: str, + headers: Headers, + request: Request, + history: t.Tuple["TestResponse"] = (), # type: ignore + **kwargs: t.Any, + ) -> None: + super().__init__(response, status, headers, **kwargs) + self.request = request + self.history = history + self._compat_tuple = response, status, headers + + def __iter__(self) -> t.Iterator: + warnings.warn( + ( + "The test client no longer returns a tuple, it returns" + " a 'TestResponse'. Tuple unpacking is deprecated and" + " will be removed in Werkzeug 2.1. Access the" + " attributes 'data', 'status', and 'headers' instead." + ), + DeprecationWarning, + stacklevel=2, + ) + return iter(self._compat_tuple) + + def __getitem__(self, item: int) -> t.Any: + warnings.warn( + ( + "The test client no longer returns a tuple, it returns" + " a 'TestResponse'. Item indexing is deprecated and" + " will be removed in Werkzeug 2.1. Access the" + " attributes 'data', 'status', and 'headers' instead." + ), + DeprecationWarning, + stacklevel=2, + ) + return self._compat_tuple[item] diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/testapp.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/testapp.py new file mode 100644 index 00000000..981f8878 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/testapp.py @@ -0,0 +1,240 @@ +"""A small application that can be used to test a WSGI server and check +it for WSGI compliance. +""" +import base64 +import os +import sys +import typing as t +from html import escape +from textwrap import wrap + +from . import __version__ as _werkzeug_version +from .wrappers.request import Request +from .wrappers.response import Response + +if t.TYPE_CHECKING: + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIEnvironment + + +logo = Response( + base64.b64decode( + """ +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 +=""" + ), + mimetype="image/png", +) + + +TEMPLATE = """\ + +WSGI Information + +

    + +

    WSGI Information

    +

    + This page displays all available information about the WSGI server and + the underlying Python interpreter. +

    Python Interpreter

    + + + + + + +
    Python Version + %(python_version)s +
    Platform + %(platform)s [%(os)s] +
    API Version + %(api_version)s +
    Byteorder + %(byteorder)s +
    Werkzeug Version + %(werkzeug_version)s +
    +

    WSGI Environment

    + %(wsgi_env)s
    +

    Installed Eggs

    +

    + The following python packages were installed on the system as + Python eggs: +

      %(python_eggs)s
    +

    System Path

    +

    + The following paths are the current contents of the load path. The + following entries are looked up for Python packages. Note that not + all items in this path are folders. Gray and underlined items are + entries pointing to invalid resources or used by custom import hooks + such as the zip importer. +

    + Items with a bright background were expanded for display from a relative + path. If you encounter such paths in the output you might want to check + your setup as relative paths are usually problematic in multithreaded + environments. +

      %(sys_path)s
    +
    +""" + + +def iter_sys_path() -> t.Iterator[t.Tuple[str, bool, bool]]: + if os.name == "posix": + + def strip(x: str) -> str: + prefix = os.path.expanduser("~") + if x.startswith(prefix): + x = f"~{x[len(prefix) :]}" + return x + + else: + + def strip(x: str) -> str: + return x + + cwd = os.path.abspath(os.getcwd()) + for item in sys.path: + path = os.path.join(cwd, item or os.path.curdir) + yield strip(os.path.normpath(path)), not os.path.isdir(path), path != item + + +def render_testapp(req: Request) -> bytes: + try: + import pkg_resources + except ImportError: + eggs: t.Iterable[t.Any] = () + else: + eggs = sorted( + pkg_resources.working_set, + key=lambda x: x.project_name.lower(), # type: ignore + ) + python_eggs = [] + for egg in eggs: + try: + version = egg.version + except (ValueError, AttributeError): + version = "unknown" + python_eggs.append( + f"
  • {escape(egg.project_name)} [{escape(version)}]" + ) + + wsgi_env = [] + sorted_environ = sorted(req.environ.items(), key=lambda x: repr(x[0]).lower()) + for key, value in sorted_environ: + value = "".join(wrap(escape(repr(value)))) + wsgi_env.append(f"{escape(str(key))}{value}") + + sys_path = [] + for item, virtual, expanded in iter_sys_path(): + class_ = [] + if virtual: + class_.append("virtual") + if expanded: + class_.append("exp") + class_ = f' class="{" ".join(class_)}"' if class_ else "" + sys_path.append(f"{escape(item)}") + + return ( + TEMPLATE + % { + "python_version": "
    ".join(escape(sys.version).splitlines()), + "platform": escape(sys.platform), + "os": escape(os.name), + "api_version": sys.api_version, + "byteorder": sys.byteorder, + "werkzeug_version": _werkzeug_version, + "python_eggs": "\n".join(python_eggs), + "wsgi_env": "\n".join(wsgi_env), + "sys_path": "\n".join(sys_path), + } + ).encode("utf-8") + + +def test_app( + environ: "WSGIEnvironment", start_response: "StartResponse" +) -> t.Iterable[bytes]: + """Simple test application that dumps the environment. You can use + it to check if Werkzeug is working properly: + + .. sourcecode:: pycon + + >>> from werkzeug.serving import run_simple + >>> from werkzeug.testapp import test_app + >>> run_simple('localhost', 3000, test_app) + * Running on http://localhost:3000/ + + The application displays important information from the WSGI environment, + the Python interpreter and the installed libraries. + """ + req = Request(environ, populate_request=False) + if req.args.get("resource") == "logo": + response = logo + else: + response = Response(render_testapp(req), mimetype="text/html") + return response(environ, start_response) + + +if __name__ == "__main__": + from .serving import run_simple + + run_simple("localhost", 5000, test_app, use_reloader=True) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/urls.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/urls.py new file mode 100644 index 00000000..9529da0c --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/urls.py @@ -0,0 +1,1211 @@ +"""Functions for working with URLs. + +Contains implementations of functions from :mod:`urllib.parse` that +handle bytes and strings. +""" +import codecs +import os +import re +import typing as t +import warnings + +from ._internal import _check_str_tuple +from ._internal import _decode_idna +from ._internal import _encode_idna +from ._internal import _make_encode_wrapper +from ._internal import _to_str + +if t.TYPE_CHECKING: + from . import datastructures as ds + +# A regular expression for what a valid schema looks like +_scheme_re = re.compile(r"^[a-zA-Z0-9+-.]+$") + +# Characters that are safe in any part of an URL. +_always_safe = frozenset( + bytearray( + b"abcdefghijklmnopqrstuvwxyz" + b"ABCDEFGHIJKLMNOPQRSTUVWXYZ" + b"0123456789" + b"-._~" + ) +) + +_hexdigits = "0123456789ABCDEFabcdef" +_hextobyte = { + f"{a}{b}".encode("ascii"): int(f"{a}{b}", 16) + for a in _hexdigits + for b in _hexdigits +} +_bytetohex = [f"%{char:02X}".encode("ascii") for char in range(256)] + + +class _URLTuple(t.NamedTuple): + scheme: str + netloc: str + path: str + query: str + fragment: str + + +class BaseURL(_URLTuple): + """Superclass of :py:class:`URL` and :py:class:`BytesURL`.""" + + __slots__ = () + _at: str + _colon: str + _lbracket: str + _rbracket: str + + def __str__(self) -> str: + return self.to_url() + + def replace(self, **kwargs: t.Any) -> "BaseURL": + """Return an URL with the same values, except for those parameters + given new values by whichever keyword arguments are specified.""" + return self._replace(**kwargs) + + @property + def host(self) -> t.Optional[str]: + """The host part of the URL if available, otherwise `None`. The + host is either the hostname or the IP address mentioned in the + URL. It will not contain the port. + """ + return self._split_host()[0] + + @property + def ascii_host(self) -> t.Optional[str]: + """Works exactly like :attr:`host` but will return a result that + is restricted to ASCII. If it finds a netloc that is not ASCII + it will attempt to idna decode it. This is useful for socket + operations when the URL might include internationalized characters. + """ + rv = self.host + if rv is not None and isinstance(rv, str): + try: + rv = _encode_idna(rv) # type: ignore + except UnicodeError: + rv = rv.encode("ascii", "ignore") # type: ignore + return _to_str(rv, "ascii", "ignore") + + @property + def port(self) -> t.Optional[int]: + """The port in the URL as an integer if it was present, `None` + otherwise. This does not fill in default ports. + """ + try: + rv = int(_to_str(self._split_host()[1])) + if 0 <= rv <= 65535: + return rv + except (ValueError, TypeError): + pass + return None + + @property + def auth(self) -> t.Optional[str]: + """The authentication part in the URL if available, `None` + otherwise. + """ + return self._split_netloc()[0] + + @property + def username(self) -> t.Optional[str]: + """The username if it was part of the URL, `None` otherwise. + This undergoes URL decoding and will always be a string. + """ + rv = self._split_auth()[0] + if rv is not None: + return _url_unquote_legacy(rv) + return None + + @property + def raw_username(self) -> t.Optional[str]: + """The username if it was part of the URL, `None` otherwise. + Unlike :attr:`username` this one is not being decoded. + """ + return self._split_auth()[0] + + @property + def password(self) -> t.Optional[str]: + """The password if it was part of the URL, `None` otherwise. + This undergoes URL decoding and will always be a string. + """ + rv = self._split_auth()[1] + if rv is not None: + return _url_unquote_legacy(rv) + return None + + @property + def raw_password(self) -> t.Optional[str]: + """The password if it was part of the URL, `None` otherwise. + Unlike :attr:`password` this one is not being decoded. + """ + return self._split_auth()[1] + + def decode_query(self, *args: t.Any, **kwargs: t.Any) -> "ds.MultiDict[str, str]": + """Decodes the query part of the URL. Ths is a shortcut for + calling :func:`url_decode` on the query argument. The arguments and + keyword arguments are forwarded to :func:`url_decode` unchanged. + """ + return url_decode(self.query, *args, **kwargs) + + def join(self, *args: t.Any, **kwargs: t.Any) -> "BaseURL": + """Joins this URL with another one. This is just a convenience + function for calling into :meth:`url_join` and then parsing the + return value again. + """ + return url_parse(url_join(self, *args, **kwargs)) + + def to_url(self) -> str: + """Returns a URL string or bytes depending on the type of the + information stored. This is just a convenience function + for calling :meth:`url_unparse` for this URL. + """ + return url_unparse(self) + + def encode_netloc(self) -> str: + """Encodes the netloc part to an ASCII safe URL as bytes.""" + rv = self.ascii_host or "" + if ":" in rv: + rv = f"[{rv}]" + port = self.port + if port is not None: + rv = f"{rv}:{port}" + auth = ":".join( + filter( + None, + [ + url_quote(self.raw_username or "", "utf-8", "strict", "/:%"), + url_quote(self.raw_password or "", "utf-8", "strict", "/:%"), + ], + ) + ) + if auth: + rv = f"{auth}@{rv}" + return rv + + def decode_netloc(self) -> str: + """Decodes the netloc part into a string.""" + rv = _decode_idna(self.host or "") + + if ":" in rv: + rv = f"[{rv}]" + port = self.port + if port is not None: + rv = f"{rv}:{port}" + auth = ":".join( + filter( + None, + [ + _url_unquote_legacy(self.raw_username or "", "/:%@"), + _url_unquote_legacy(self.raw_password or "", "/:%@"), + ], + ) + ) + if auth: + rv = f"{auth}@{rv}" + return rv + + def to_uri_tuple(self) -> "BaseURL": + """Returns a :class:`BytesURL` tuple that holds a URI. This will + encode all the information in the URL properly to ASCII using the + rules a web browser would follow. + + It's usually more interesting to directly call :meth:`iri_to_uri` which + will return a string. + """ + return url_parse(iri_to_uri(self)) + + def to_iri_tuple(self) -> "BaseURL": + """Returns a :class:`URL` tuple that holds a IRI. This will try + to decode as much information as possible in the URL without + losing information similar to how a web browser does it for the + URL bar. + + It's usually more interesting to directly call :meth:`uri_to_iri` which + will return a string. + """ + return url_parse(uri_to_iri(self)) + + def get_file_location( + self, pathformat: t.Optional[str] = None + ) -> t.Tuple[t.Optional[str], t.Optional[str]]: + """Returns a tuple with the location of the file in the form + ``(server, location)``. If the netloc is empty in the URL or + points to localhost, it's represented as ``None``. + + The `pathformat` by default is autodetection but needs to be set + when working with URLs of a specific system. The supported values + are ``'windows'`` when working with Windows or DOS paths and + ``'posix'`` when working with posix paths. + + If the URL does not point to a local file, the server and location + are both represented as ``None``. + + :param pathformat: The expected format of the path component. + Currently ``'windows'`` and ``'posix'`` are + supported. Defaults to ``None`` which is + autodetect. + """ + if self.scheme != "file": + return None, None + + path = url_unquote(self.path) + host = self.netloc or None + + if pathformat is None: + if os.name == "nt": + pathformat = "windows" + else: + pathformat = "posix" + + if pathformat == "windows": + if path[:1] == "/" and path[1:2].isalpha() and path[2:3] in "|:": + path = f"{path[1:2]}:{path[3:]}" + windows_share = path[:3] in ("\\" * 3, "/" * 3) + import ntpath + + path = ntpath.normpath(path) + # Windows shared drives are represented as ``\\host\\directory``. + # That results in a URL like ``file://///host/directory``, and a + # path like ``///host/directory``. We need to special-case this + # because the path contains the hostname. + if windows_share and host is None: + parts = path.lstrip("\\").split("\\", 1) + if len(parts) == 2: + host, path = parts + else: + host = parts[0] + path = "" + elif pathformat == "posix": + import posixpath + + path = posixpath.normpath(path) + else: + raise TypeError(f"Invalid path format {pathformat!r}") + + if host in ("127.0.0.1", "::1", "localhost"): + host = None + + return host, path + + def _split_netloc(self) -> t.Tuple[t.Optional[str], str]: + if self._at in self.netloc: + auth, _, netloc = self.netloc.partition(self._at) + return auth, netloc + return None, self.netloc + + def _split_auth(self) -> t.Tuple[t.Optional[str], t.Optional[str]]: + auth = self._split_netloc()[0] + if not auth: + return None, None + if self._colon not in auth: + return auth, None + + username, _, password = auth.partition(self._colon) + return username, password + + def _split_host(self) -> t.Tuple[t.Optional[str], t.Optional[str]]: + rv = self._split_netloc()[1] + if not rv: + return None, None + + if not rv.startswith(self._lbracket): + if self._colon in rv: + host, _, port = rv.partition(self._colon) + return host, port + return rv, None + + idx = rv.find(self._rbracket) + if idx < 0: + return rv, None + + host = rv[1:idx] + rest = rv[idx + 1 :] + if rest.startswith(self._colon): + return host, rest[1:] + return host, None + + +class URL(BaseURL): + """Represents a parsed URL. This behaves like a regular tuple but + also has some extra attributes that give further insight into the + URL. + """ + + __slots__ = () + _at = "@" + _colon = ":" + _lbracket = "[" + _rbracket = "]" + + def encode(self, charset: str = "utf-8", errors: str = "replace") -> "BytesURL": + """Encodes the URL to a tuple made out of bytes. The charset is + only being used for the path, query and fragment. + """ + return BytesURL( + self.scheme.encode("ascii"), # type: ignore + self.encode_netloc(), + self.path.encode(charset, errors), # type: ignore + self.query.encode(charset, errors), # type: ignore + self.fragment.encode(charset, errors), # type: ignore + ) + + +class BytesURL(BaseURL): + """Represents a parsed URL in bytes.""" + + __slots__ = () + _at = b"@" # type: ignore + _colon = b":" # type: ignore + _lbracket = b"[" # type: ignore + _rbracket = b"]" # type: ignore + + def __str__(self) -> str: + return self.to_url().decode("utf-8", "replace") # type: ignore + + def encode_netloc(self) -> bytes: # type: ignore + """Returns the netloc unchanged as bytes.""" + return self.netloc # type: ignore + + def decode(self, charset: str = "utf-8", errors: str = "replace") -> "URL": + """Decodes the URL to a tuple made out of strings. The charset is + only being used for the path, query and fragment. + """ + return URL( + self.scheme.decode("ascii"), # type: ignore + self.decode_netloc(), + self.path.decode(charset, errors), # type: ignore + self.query.decode(charset, errors), # type: ignore + self.fragment.decode(charset, errors), # type: ignore + ) + + +_unquote_maps: t.Dict[t.FrozenSet[int], t.Dict[bytes, int]] = {frozenset(): _hextobyte} + + +def _unquote_to_bytes( + string: t.Union[str, bytes], unsafe: t.Union[str, bytes] = "" +) -> bytes: + if isinstance(string, str): + string = string.encode("utf-8") + + if isinstance(unsafe, str): + unsafe = unsafe.encode("utf-8") + + unsafe = frozenset(bytearray(unsafe)) + groups = iter(string.split(b"%")) + result = bytearray(next(groups, b"")) + + try: + hex_to_byte = _unquote_maps[unsafe] + except KeyError: + hex_to_byte = _unquote_maps[unsafe] = { + h: b for h, b in _hextobyte.items() if b not in unsafe + } + + for group in groups: + code = group[:2] + + if code in hex_to_byte: + result.append(hex_to_byte[code]) + result.extend(group[2:]) + else: + result.append(37) # % + result.extend(group) + + return bytes(result) + + +def _url_encode_impl( + obj: t.Union[t.Mapping[str, str], t.Iterable[t.Tuple[str, str]]], + charset: str, + sort: bool, + key: t.Optional[t.Callable[[t.Tuple[str, str]], t.Any]], +) -> t.Iterator[str]: + from .datastructures import iter_multi_items + + iterable: t.Iterable[t.Tuple[str, str]] = iter_multi_items(obj) + + if sort: + iterable = sorted(iterable, key=key) + + for key_str, value_str in iterable: + if value_str is None: + continue + + if not isinstance(key_str, bytes): + key_bytes = str(key_str).encode(charset) + else: + key_bytes = key_str + + if not isinstance(value_str, bytes): + value_bytes = str(value_str).encode(charset) + else: + value_bytes = value_str + + yield f"{_fast_url_quote_plus(key_bytes)}={_fast_url_quote_plus(value_bytes)}" + + +def _url_unquote_legacy(value: str, unsafe: str = "") -> str: + try: + return url_unquote(value, charset="utf-8", errors="strict", unsafe=unsafe) + except UnicodeError: + return url_unquote(value, charset="latin1", unsafe=unsafe) + + +def url_parse( + url: str, scheme: t.Optional[str] = None, allow_fragments: bool = True +) -> BaseURL: + """Parses a URL from a string into a :class:`URL` tuple. If the URL + is lacking a scheme it can be provided as second argument. Otherwise, + it is ignored. Optionally fragments can be stripped from the URL + by setting `allow_fragments` to `False`. + + The inverse of this function is :func:`url_unparse`. + + :param url: the URL to parse. + :param scheme: the default schema to use if the URL is schemaless. + :param allow_fragments: if set to `False` a fragment will be removed + from the URL. + """ + s = _make_encode_wrapper(url) + is_text_based = isinstance(url, str) + + if scheme is None: + scheme = s("") + netloc = query = fragment = s("") + i = url.find(s(":")) + if i > 0 and _scheme_re.match(_to_str(url[:i], errors="replace")): + # make sure "iri" is not actually a port number (in which case + # "scheme" is really part of the path) + rest = url[i + 1 :] + if not rest or any(c not in s("0123456789") for c in rest): + # not a port number + scheme, url = url[:i].lower(), rest + + if url[:2] == s("//"): + delim = len(url) + for c in s("/?#"): + wdelim = url.find(c, 2) + if wdelim >= 0: + delim = min(delim, wdelim) + netloc, url = url[2:delim], url[delim:] + if (s("[") in netloc and s("]") not in netloc) or ( + s("]") in netloc and s("[") not in netloc + ): + raise ValueError("Invalid IPv6 URL") + + if allow_fragments and s("#") in url: + url, fragment = url.split(s("#"), 1) + if s("?") in url: + url, query = url.split(s("?"), 1) + + result_type = URL if is_text_based else BytesURL + return result_type(scheme, netloc, url, query, fragment) + + +def _make_fast_url_quote( + charset: str = "utf-8", + errors: str = "strict", + safe: t.Union[str, bytes] = "/:", + unsafe: t.Union[str, bytes] = "", +) -> t.Callable[[bytes], str]: + """Precompile the translation table for a URL encoding function. + + Unlike :func:`url_quote`, the generated function only takes the + string to quote. + + :param charset: The charset to encode the result with. + :param errors: How to handle encoding errors. + :param safe: An optional sequence of safe characters to never encode. + :param unsafe: An optional sequence of unsafe characters to always encode. + """ + if isinstance(safe, str): + safe = safe.encode(charset, errors) + + if isinstance(unsafe, str): + unsafe = unsafe.encode(charset, errors) + + safe = (frozenset(bytearray(safe)) | _always_safe) - frozenset(bytearray(unsafe)) + table = [chr(c) if c in safe else f"%{c:02X}" for c in range(256)] + + def quote(string: bytes) -> str: + return "".join([table[c] for c in string]) + + return quote + + +_fast_url_quote = _make_fast_url_quote() +_fast_quote_plus = _make_fast_url_quote(safe=" ", unsafe="+") + + +def _fast_url_quote_plus(string: bytes) -> str: + return _fast_quote_plus(string).replace(" ", "+") + + +def url_quote( + string: t.Union[str, bytes], + charset: str = "utf-8", + errors: str = "strict", + safe: t.Union[str, bytes] = "/:", + unsafe: t.Union[str, bytes] = "", +) -> str: + """URL encode a single string with a given encoding. + + :param s: the string to quote. + :param charset: the charset to be used. + :param safe: an optional sequence of safe characters. + :param unsafe: an optional sequence of unsafe characters. + + .. versionadded:: 0.9.2 + The `unsafe` parameter was added. + """ + if not isinstance(string, (str, bytes, bytearray)): + string = str(string) + if isinstance(string, str): + string = string.encode(charset, errors) + if isinstance(safe, str): + safe = safe.encode(charset, errors) + if isinstance(unsafe, str): + unsafe = unsafe.encode(charset, errors) + safe = (frozenset(bytearray(safe)) | _always_safe) - frozenset(bytearray(unsafe)) + rv = bytearray() + for char in bytearray(string): + if char in safe: + rv.append(char) + else: + rv.extend(_bytetohex[char]) + return bytes(rv).decode(charset) + + +def url_quote_plus( + string: str, charset: str = "utf-8", errors: str = "strict", safe: str = "" +) -> str: + """URL encode a single string with the given encoding and convert + whitespace to "+". + + :param s: The string to quote. + :param charset: The charset to be used. + :param safe: An optional sequence of safe characters. + """ + return url_quote(string, charset, errors, safe + " ", "+").replace(" ", "+") + + +def url_unparse(components: t.Tuple[str, str, str, str, str]) -> str: + """The reverse operation to :meth:`url_parse`. This accepts arbitrary + as well as :class:`URL` tuples and returns a URL as a string. + + :param components: the parsed URL as tuple which should be converted + into a URL string. + """ + _check_str_tuple(components) + scheme, netloc, path, query, fragment = components + s = _make_encode_wrapper(scheme) + url = s("") + + # We generally treat file:///x and file:/x the same which is also + # what browsers seem to do. This also allows us to ignore a schema + # register for netloc utilization or having to differentiate between + # empty and missing netloc. + if netloc or (scheme and path.startswith(s("/"))): + if path and path[:1] != s("/"): + path = s("/") + path + url = s("//") + (netloc or s("")) + path + elif path: + url += path + if scheme: + url = scheme + s(":") + url + if query: + url = url + s("?") + query + if fragment: + url = url + s("#") + fragment + return url + + +def url_unquote( + s: t.Union[str, bytes], + charset: str = "utf-8", + errors: str = "replace", + unsafe: str = "", +) -> str: + """URL decode a single string with a given encoding. If the charset + is set to `None` no decoding is performed and raw bytes are + returned. + + :param s: the string to unquote. + :param charset: the charset of the query string. If set to `None` + no decoding will take place. + :param errors: the error handling for the charset decoding. + """ + rv = _unquote_to_bytes(s, unsafe) + if charset is None: + return rv + return rv.decode(charset, errors) + + +def url_unquote_plus( + s: t.Union[str, bytes], charset: str = "utf-8", errors: str = "replace" +) -> str: + """URL decode a single string with the given `charset` and decode "+" to + whitespace. + + Per default encoding errors are ignored. If you want a different behavior + you can set `errors` to ``'replace'`` or ``'strict'``. + + :param s: The string to unquote. + :param charset: the charset of the query string. If set to `None` + no decoding will take place. + :param errors: The error handling for the `charset` decoding. + """ + if isinstance(s, str): + s = s.replace("+", " ") + else: + s = s.replace(b"+", b" ") + return url_unquote(s, charset, errors) + + +def url_fix(s: str, charset: str = "utf-8") -> str: + r"""Sometimes you get an URL by a user that just isn't a real URL because + it contains unsafe characters like ' ' and so on. This function can fix + some of the problems in a similar way browsers handle data entered by the + user: + + >>> url_fix('http://de.wikipedia.org/wiki/Elf (Begriffskl\xe4rung)') + 'http://de.wikipedia.org/wiki/Elf%20(Begriffskl%C3%A4rung)' + + :param s: the string with the URL to fix. + :param charset: The target charset for the URL if the url was given + as a string. + """ + # First step is to switch to text processing and to convert + # backslashes (which are invalid in URLs anyways) to slashes. This is + # consistent with what Chrome does. + s = _to_str(s, charset, "replace").replace("\\", "/") + + # For the specific case that we look like a malformed windows URL + # we want to fix this up manually: + if s.startswith("file://") and s[7:8].isalpha() and s[8:10] in (":/", "|/"): + s = f"file:///{s[7:]}" + + url = url_parse(s) + path = url_quote(url.path, charset, safe="/%+$!*'(),") + qs = url_quote_plus(url.query, charset, safe=":&%=+$!*'(),") + anchor = url_quote_plus(url.fragment, charset, safe=":&%=+$!*'(),") + return url_unparse((url.scheme, url.encode_netloc(), path, qs, anchor)) + + +# not-unreserved characters remain quoted when unquoting to IRI +_to_iri_unsafe = "".join([chr(c) for c in range(128) if c not in _always_safe]) + + +def _codec_error_url_quote(e: UnicodeError) -> t.Tuple[str, int]: + """Used in :func:`uri_to_iri` after unquoting to re-quote any + invalid bytes. + """ + # the docs state that UnicodeError does have these attributes, + # but mypy isn't picking them up + out = _fast_url_quote(e.object[e.start : e.end]) # type: ignore + return out, e.end # type: ignore + + +codecs.register_error("werkzeug.url_quote", _codec_error_url_quote) + + +def uri_to_iri( + uri: t.Union[str, t.Tuple[str, str, str, str, str]], + charset: str = "utf-8", + errors: str = "werkzeug.url_quote", +) -> str: + """Convert a URI to an IRI. All valid UTF-8 characters are unquoted, + leaving all reserved and invalid characters quoted. If the URL has + a domain, it is decoded from Punycode. + + >>> uri_to_iri("http://xn--n3h.net/p%C3%A5th?q=%C3%A8ry%DF") + 'http://\\u2603.net/p\\xe5th?q=\\xe8ry%DF' + + :param uri: The URI to convert. + :param charset: The encoding to encode unquoted bytes with. + :param errors: Error handler to use during ``bytes.encode``. By + default, invalid bytes are left quoted. + + .. versionchanged:: 0.15 + All reserved and invalid characters remain quoted. Previously, + only some reserved characters were preserved, and invalid bytes + were replaced instead of left quoted. + + .. versionadded:: 0.6 + """ + if isinstance(uri, tuple): + uri = url_unparse(uri) + + uri = url_parse(_to_str(uri, charset)) + path = url_unquote(uri.path, charset, errors, _to_iri_unsafe) + query = url_unquote(uri.query, charset, errors, _to_iri_unsafe) + fragment = url_unquote(uri.fragment, charset, errors, _to_iri_unsafe) + return url_unparse((uri.scheme, uri.decode_netloc(), path, query, fragment)) + + +# reserved characters remain unquoted when quoting to URI +_to_uri_safe = ":/?#[]@!$&'()*+,;=%" + + +def iri_to_uri( + iri: t.Union[str, t.Tuple[str, str, str, str, str]], + charset: str = "utf-8", + errors: str = "strict", + safe_conversion: bool = False, +) -> str: + """Convert an IRI to a URI. All non-ASCII and unsafe characters are + quoted. If the URL has a domain, it is encoded to Punycode. + + >>> iri_to_uri('http://\\u2603.net/p\\xe5th?q=\\xe8ry%DF') + 'http://xn--n3h.net/p%C3%A5th?q=%C3%A8ry%DF' + + :param iri: The IRI to convert. + :param charset: The encoding of the IRI. + :param errors: Error handler to use during ``bytes.encode``. + :param safe_conversion: Return the URL unchanged if it only contains + ASCII characters and no whitespace. See the explanation below. + + There is a general problem with IRI conversion with some protocols + that are in violation of the URI specification. Consider the + following two IRIs:: + + magnet:?xt=uri:whatever + itms-services://?action=download-manifest + + After parsing, we don't know if the scheme requires the ``//``, + which is dropped if empty, but conveys different meanings in the + final URL if it's present or not. In this case, you can use + ``safe_conversion``, which will return the URL unchanged if it only + contains ASCII characters and no whitespace. This can result in a + URI with unquoted characters if it was not already quoted correctly, + but preserves the URL's semantics. Werkzeug uses this for the + ``Location`` header for redirects. + + .. versionchanged:: 0.15 + All reserved characters remain unquoted. Previously, only some + reserved characters were left unquoted. + + .. versionchanged:: 0.9.6 + The ``safe_conversion`` parameter was added. + + .. versionadded:: 0.6 + """ + if isinstance(iri, tuple): + iri = url_unparse(iri) + + if safe_conversion: + # If we're not sure if it's safe to convert the URL, and it only + # contains ASCII characters, return it unconverted. + try: + native_iri = _to_str(iri) + ascii_iri = native_iri.encode("ascii") + + # Only return if it doesn't have whitespace. (Why?) + if len(ascii_iri.split()) == 1: + return native_iri + except UnicodeError: + pass + + iri = url_parse(_to_str(iri, charset, errors)) + path = url_quote(iri.path, charset, errors, _to_uri_safe) + query = url_quote(iri.query, charset, errors, _to_uri_safe) + fragment = url_quote(iri.fragment, charset, errors, _to_uri_safe) + return url_unparse((iri.scheme, iri.encode_netloc(), path, query, fragment)) + + +def url_decode( + s: t.AnyStr, + charset: str = "utf-8", + decode_keys: None = None, + include_empty: bool = True, + errors: str = "replace", + separator: str = "&", + cls: t.Optional[t.Type["ds.MultiDict"]] = None, +) -> "ds.MultiDict[str, str]": + """Parse a query string and return it as a :class:`MultiDict`. + + :param s: The query string to parse. + :param charset: Decode bytes to string with this charset. If not + given, bytes are returned as-is. + :param include_empty: Include keys with empty values in the dict. + :param errors: Error handling behavior when decoding bytes. + :param separator: Separator character between pairs. + :param cls: Container to hold result instead of :class:`MultiDict`. + + .. versionchanged:: 2.0 + The ``decode_keys`` parameter is deprecated and will be removed + in Werkzeug 2.1. + + .. versionchanged:: 0.5 + In previous versions ";" and "&" could be used for url decoding. + Now only "&" is supported. If you want to use ";", a different + ``separator`` can be provided. + + .. versionchanged:: 0.5 + The ``cls`` parameter was added. + """ + if decode_keys is not None: + warnings.warn( + "'decode_keys' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + if cls is None: + from .datastructures import MultiDict # noqa: F811 + + cls = MultiDict + if isinstance(s, str) and not isinstance(separator, str): + separator = separator.decode(charset or "ascii") + elif isinstance(s, bytes) and not isinstance(separator, bytes): + separator = separator.encode(charset or "ascii") # type: ignore + return cls( + _url_decode_impl( + s.split(separator), charset, include_empty, errors # type: ignore + ) + ) + + +def url_decode_stream( + stream: t.IO[bytes], + charset: str = "utf-8", + decode_keys: None = None, + include_empty: bool = True, + errors: str = "replace", + separator: bytes = b"&", + cls: t.Optional[t.Type["ds.MultiDict"]] = None, + limit: t.Optional[int] = None, + return_iterator: bool = False, +) -> "ds.MultiDict[str, str]": + """Works like :func:`url_decode` but decodes a stream. The behavior + of stream and limit follows functions like + :func:`~werkzeug.wsgi.make_line_iter`. The generator of pairs is + directly fed to the `cls` so you can consume the data while it's + parsed. + + :param stream: a stream with the encoded querystring + :param charset: the charset of the query string. If set to `None` + no decoding will take place. + :param include_empty: Set to `False` if you don't want empty values to + appear in the dict. + :param errors: the decoding error behavior. + :param separator: the pair separator to be used, defaults to ``&`` + :param cls: an optional dict class to use. If this is not specified + or `None` the default :class:`MultiDict` is used. + :param limit: the content length of the URL data. Not necessary if + a limited stream is provided. + + .. versionchanged:: 2.0 + The ``decode_keys`` and ``return_iterator`` parameters are + deprecated and will be removed in Werkzeug 2.1. + + .. versionadded:: 0.8 + """ + from .wsgi import make_chunk_iter + + if decode_keys is not None: + warnings.warn( + "'decode_keys' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + + pair_iter = make_chunk_iter(stream, separator, limit) + decoder = _url_decode_impl(pair_iter, charset, include_empty, errors) + + if return_iterator: + warnings.warn( + "'return_iterator' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + return decoder # type: ignore + + if cls is None: + from .datastructures import MultiDict # noqa: F811 + + cls = MultiDict + + return cls(decoder) + + +def _url_decode_impl( + pair_iter: t.Iterable[t.AnyStr], charset: str, include_empty: bool, errors: str +) -> t.Iterator[t.Tuple[str, str]]: + for pair in pair_iter: + if not pair: + continue + s = _make_encode_wrapper(pair) + equal = s("=") + if equal in pair: + key, value = pair.split(equal, 1) + else: + if not include_empty: + continue + key = pair + value = s("") + yield ( + url_unquote_plus(key, charset, errors), + url_unquote_plus(value, charset, errors), + ) + + +def url_encode( + obj: t.Union[t.Mapping[str, str], t.Iterable[t.Tuple[str, str]]], + charset: str = "utf-8", + encode_keys: None = None, + sort: bool = False, + key: t.Optional[t.Callable[[t.Tuple[str, str]], t.Any]] = None, + separator: str = "&", +) -> str: + """URL encode a dict/`MultiDict`. If a value is `None` it will not appear + in the result string. Per default only values are encoded into the target + charset strings. + + :param obj: the object to encode into a query string. + :param charset: the charset of the query string. + :param sort: set to `True` if you want parameters to be sorted by `key`. + :param separator: the separator to be used for the pairs. + :param key: an optional function to be used for sorting. For more details + check out the :func:`sorted` documentation. + + .. versionchanged:: 2.0 + The ``encode_keys`` parameter is deprecated and will be removed + in Werkzeug 2.1. + + .. versionchanged:: 0.5 + Added the ``sort``, ``key``, and ``separator`` parameters. + """ + if encode_keys is not None: + warnings.warn( + "'encode_keys' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + separator = _to_str(separator, "ascii") + return separator.join(_url_encode_impl(obj, charset, sort, key)) + + +def url_encode_stream( + obj: t.Union[t.Mapping[str, str], t.Iterable[t.Tuple[str, str]]], + stream: t.Optional[t.IO[str]] = None, + charset: str = "utf-8", + encode_keys: None = None, + sort: bool = False, + key: t.Optional[t.Callable[[t.Tuple[str, str]], t.Any]] = None, + separator: str = "&", +) -> None: + """Like :meth:`url_encode` but writes the results to a stream + object. If the stream is `None` a generator over all encoded + pairs is returned. + + :param obj: the object to encode into a query string. + :param stream: a stream to write the encoded object into or `None` if + an iterator over the encoded pairs should be returned. In + that case the separator argument is ignored. + :param charset: the charset of the query string. + :param sort: set to `True` if you want parameters to be sorted by `key`. + :param separator: the separator to be used for the pairs. + :param key: an optional function to be used for sorting. For more details + check out the :func:`sorted` documentation. + + .. versionchanged:: 2.0 + The ``encode_keys`` parameter is deprecated and will be removed + in Werkzeug 2.1. + + .. versionadded:: 0.8 + """ + if encode_keys is not None: + warnings.warn( + "'encode_keys' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + separator = _to_str(separator, "ascii") + gen = _url_encode_impl(obj, charset, sort, key) + if stream is None: + return gen # type: ignore + for idx, chunk in enumerate(gen): + if idx: + stream.write(separator) + stream.write(chunk) + return None + + +def url_join( + base: t.Union[str, t.Tuple[str, str, str, str, str]], + url: t.Union[str, t.Tuple[str, str, str, str, str]], + allow_fragments: bool = True, +) -> str: + """Join a base URL and a possibly relative URL to form an absolute + interpretation of the latter. + + :param base: the base URL for the join operation. + :param url: the URL to join. + :param allow_fragments: indicates whether fragments should be allowed. + """ + if isinstance(base, tuple): + base = url_unparse(base) + if isinstance(url, tuple): + url = url_unparse(url) + + _check_str_tuple((base, url)) + s = _make_encode_wrapper(base) + + if not base: + return url + if not url: + return base + + bscheme, bnetloc, bpath, bquery, bfragment = url_parse( + base, allow_fragments=allow_fragments + ) + scheme, netloc, path, query, fragment = url_parse(url, bscheme, allow_fragments) + if scheme != bscheme: + return url + if netloc: + return url_unparse((scheme, netloc, path, query, fragment)) + netloc = bnetloc + + if path[:1] == s("/"): + segments = path.split(s("/")) + elif not path: + segments = bpath.split(s("/")) + if not query: + query = bquery + else: + segments = bpath.split(s("/"))[:-1] + path.split(s("/")) + + # If the rightmost part is "./" we want to keep the slash but + # remove the dot. + if segments[-1] == s("."): + segments[-1] = s("") + + # Resolve ".." and "." + segments = [segment for segment in segments if segment != s(".")] + while True: + i = 1 + n = len(segments) - 1 + while i < n: + if segments[i] == s("..") and segments[i - 1] not in (s(""), s("..")): + del segments[i - 1 : i + 1] + break + i += 1 + else: + break + + # Remove trailing ".." if the URL is absolute + unwanted_marker = [s(""), s("..")] + while segments[:2] == unwanted_marker: + del segments[1] + + path = s("/").join(segments) + return url_unparse((scheme, netloc, path, query, fragment)) + + +class Href: + """Implements a callable that constructs URLs with the given base. The + function can be called with any number of positional and keyword + arguments which than are used to assemble the URL. Works with URLs + and posix paths. + + Positional arguments are appended as individual segments to + the path of the URL: + + >>> href = Href('/foo') + >>> href('bar', 23) + '/foo/bar/23' + >>> href('foo', bar=23) + '/foo/foo?bar=23' + + If any of the arguments (positional or keyword) evaluates to `None` it + will be skipped. If no keyword arguments are given the last argument + can be a :class:`dict` or :class:`MultiDict` (or any other dict subclass), + otherwise the keyword arguments are used for the query parameters, cutting + off the first trailing underscore of the parameter name: + + >>> href(is_=42) + '/foo?is=42' + >>> href({'foo': 'bar'}) + '/foo?foo=bar' + + Combining of both methods is not allowed: + + >>> href({'foo': 'bar'}, bar=42) + Traceback (most recent call last): + ... + TypeError: keyword arguments and query-dicts can't be combined + + Accessing attributes on the href object creates a new href object with + the attribute name as prefix: + + >>> bar_href = href.bar + >>> bar_href("blub") + '/foo/bar/blub' + + If `sort` is set to `True` the items are sorted by `key` or the default + sorting algorithm: + + >>> href = Href("/", sort=True) + >>> href(a=1, b=2, c=3) + '/?a=1&b=2&c=3' + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :mod:`werkzeug.routing` + instead. + + .. versionadded:: 0.5 + `sort` and `key` were added. + """ + + def __init__( # type: ignore + self, base="./", charset="utf-8", sort=False, key=None + ): + warnings.warn( + "'Href' is deprecated and will be removed in Werkzeug 2.1." + " Use 'werkzeug.routing' instead.", + DeprecationWarning, + stacklevel=2, + ) + + if not base: + base = "./" + self.base = base + self.charset = charset + self.sort = sort + self.key = key + + def __getattr__(self, name): # type: ignore + if name[:2] == "__": + raise AttributeError(name) + base = self.base + if base[-1:] != "/": + base += "/" + return Href(url_join(base, name), self.charset, self.sort, self.key) + + def __call__(self, *path, **query): # type: ignore + if path and isinstance(path[-1], dict): + if query: + raise TypeError("keyword arguments and query-dicts can't be combined") + query, path = path[-1], path[:-1] + elif query: + query = {k[:-1] if k.endswith("_") else k: v for k, v in query.items()} + path = "/".join( + [ + _to_str(url_quote(x, self.charset), "ascii") + for x in path + if x is not None + ] + ).lstrip("/") + rv = self.base + if path: + if not rv.endswith("/"): + rv += "/" + rv = url_join(rv, f"./{path}") + if query: + rv += "?" + _to_str( + url_encode(query, self.charset, sort=self.sort, key=self.key), "ascii" + ) + return rv diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/user_agent.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/user_agent.py new file mode 100644 index 00000000..66ffcbe0 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/user_agent.py @@ -0,0 +1,47 @@ +import typing as t + + +class UserAgent: + """Represents a parsed user agent header value. + + The default implementation does no parsing, only the :attr:`string` + attribute is set. A subclass may parse the string to set the + common attributes or expose other information. Set + :attr:`werkzeug.wrappers.Request.user_agent_class` to use a + subclass. + + :param string: The header value to parse. + + .. versionadded:: 2.0 + This replaces the previous ``useragents`` module, but does not + provide a built-in parser. + """ + + platform: t.Optional[str] = None + """The OS name, if it could be parsed from the string.""" + + browser: t.Optional[str] = None + """The browser name, if it could be parsed from the string.""" + + version: t.Optional[str] = None + """The browser version, if it could be parsed from the string.""" + + language: t.Optional[str] = None + """The browser language, if it could be parsed from the string.""" + + def __init__(self, string: str) -> None: + self.string: str = string + """The original header value.""" + + def __repr__(self) -> str: + return f"<{type(self).__name__} {self.browser}/{self.version}>" + + def __str__(self) -> str: + return self.string + + def __bool__(self) -> bool: + return bool(self.browser) + + def to_header(self) -> str: + """Convert to a header value.""" + return self.string diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/useragents.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/useragents.py new file mode 100644 index 00000000..4deed8f4 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/useragents.py @@ -0,0 +1,215 @@ +import re +import typing as t +import warnings + +from .user_agent import UserAgent as _BaseUserAgent + +if t.TYPE_CHECKING: + from _typeshed.wsgi import WSGIEnvironment + + +class _UserAgentParser: + platform_rules: t.ClassVar[t.Iterable[t.Tuple[str, str]]] = ( + (" cros ", "chromeos"), + ("iphone|ios", "iphone"), + ("ipad", "ipad"), + (r"darwin\b|mac\b|os\s*x", "macos"), + ("win", "windows"), + (r"android", "android"), + ("netbsd", "netbsd"), + ("openbsd", "openbsd"), + ("freebsd", "freebsd"), + ("dragonfly", "dragonflybsd"), + ("(sun|i86)os", "solaris"), + (r"x11\b|lin(\b|ux)?", "linux"), + (r"nintendo\s+wii", "wii"), + ("irix", "irix"), + ("hp-?ux", "hpux"), + ("aix", "aix"), + ("sco|unix_sv", "sco"), + ("bsd", "bsd"), + ("amiga", "amiga"), + ("blackberry|playbook", "blackberry"), + ("symbian", "symbian"), + ) + browser_rules: t.ClassVar[t.Iterable[t.Tuple[str, str]]] = ( + ("googlebot", "google"), + ("msnbot", "msn"), + ("yahoo", "yahoo"), + ("ask jeeves", "ask"), + (r"aol|america\s+online\s+browser", "aol"), + (r"opera|opr", "opera"), + ("edge|edg", "edge"), + ("chrome|crios", "chrome"), + ("seamonkey", "seamonkey"), + ("firefox|firebird|phoenix|iceweasel", "firefox"), + ("galeon", "galeon"), + ("safari|version", "safari"), + ("webkit", "webkit"), + ("camino", "camino"), + ("konqueror", "konqueror"), + ("k-meleon", "kmeleon"), + ("netscape", "netscape"), + (r"msie|microsoft\s+internet\s+explorer|trident/.+? rv:", "msie"), + ("lynx", "lynx"), + ("links", "links"), + ("Baiduspider", "baidu"), + ("bingbot", "bing"), + ("mozilla", "mozilla"), + ) + + _browser_version_re = r"(?:{pattern})[/\sa-z(]*(\d+[.\da-z]+)?" + _language_re = re.compile( + r"(?:;\s*|\s+)(\b\w{2}\b(?:-\b\w{2}\b)?)\s*;|" + r"(?:\(|\[|;)\s*(\b\w{2}\b(?:-\b\w{2}\b)?)\s*(?:\]|\)|;)" + ) + + def __init__(self) -> None: + self.platforms = [(b, re.compile(a, re.I)) for a, b in self.platform_rules] + self.browsers = [ + (b, re.compile(self._browser_version_re.format(pattern=a), re.I)) + for a, b in self.browser_rules + ] + + def __call__( + self, user_agent: str + ) -> t.Tuple[t.Optional[str], t.Optional[str], t.Optional[str], t.Optional[str]]: + platform: t.Optional[str] + browser: t.Optional[str] + version: t.Optional[str] + language: t.Optional[str] + + for platform, regex in self.platforms: # noqa: B007 + match = regex.search(user_agent) + if match is not None: + break + else: + platform = None + + # Except for Trident, all browser key words come after the last ')' + last_closing_paren = 0 + if ( + not re.compile(r"trident/.+? rv:", re.I).search(user_agent) + and ")" in user_agent + and user_agent[-1] != ")" + ): + last_closing_paren = user_agent.rindex(")") + + for browser, regex in self.browsers: # noqa: B007 + match = regex.search(user_agent[last_closing_paren:]) + if match is not None: + version = match.group(1) + break + else: + browser = version = None + match = self._language_re.search(user_agent) + if match is not None: + language = match.group(1) or match.group(2) + else: + language = None + return platform, browser, version, language + + +# It wasn't public, but users might have imported it anyway, show a +# warning if a user created an instance. +class UserAgentParser(_UserAgentParser): + """A simple user agent parser. Used by the `UserAgent`. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use a dedicated parser library + instead. + """ + + def __init__(self) -> None: + warnings.warn( + "'UserAgentParser' is deprecated and will be removed in" + " Werkzeug 2.1. Use a dedicated parser library instead.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__() + + +class _deprecated_property(property): + def __init__(self, fget: t.Callable[["_UserAgent"], t.Any]) -> None: + super().__init__(fget) + self.message = ( + "The built-in user agent parser is deprecated and will be" + f" removed in Werkzeug 2.1. The {fget.__name__!r} property" + " will be 'None'. Subclass 'werkzeug.user_agent.UserAgent'" + " and set 'Request.user_agent_class' to use a different" + " parser." + ) + + def __get__(self, *args: t.Any, **kwargs: t.Any) -> t.Any: + warnings.warn(self.message, DeprecationWarning, stacklevel=3) + return super().__get__(*args, **kwargs) + + +# This is what Request.user_agent returns for now, only show warnings on +# attribute access, not creation. +class _UserAgent(_BaseUserAgent): + _parser = _UserAgentParser() + + def __init__(self, string: str) -> None: + super().__init__(string) + info = self._parser(string) + self._platform, self._browser, self._version, self._language = info + + @_deprecated_property + def platform(self) -> t.Optional[str]: # type: ignore + return self._platform + + @_deprecated_property + def browser(self) -> t.Optional[str]: # type: ignore + return self._browser + + @_deprecated_property + def version(self) -> t.Optional[str]: # type: ignore + return self._version + + @_deprecated_property + def language(self) -> t.Optional[str]: # type: ignore + return self._language + + +# This is what users might be importing, show warnings on create. +class UserAgent(_UserAgent): + """Represents a parsed user agent header value. + + This uses a basic parser to try to extract some information from the + header. + + :param environ_or_string: The header value to parse, or a WSGI + environ containing the header. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Subclass + :class:`werkzeug.user_agent.UserAgent` (note the new module + name) to use a dedicated parser instead. + + .. versionchanged:: 2.0 + Passing a WSGI environ is deprecated and will be removed in 2.1. + """ + + def __init__(self, environ_or_string: "t.Union[str, WSGIEnvironment]") -> None: + if isinstance(environ_or_string, dict): + warnings.warn( + "Passing an environ to 'UserAgent' is deprecated and" + " will be removed in Werkzeug 2.1. Pass the header" + " value string instead.", + DeprecationWarning, + stacklevel=2, + ) + string = environ_or_string.get("HTTP_USER_AGENT", "") + else: + string = environ_or_string + + warnings.warn( + "The 'werkzeug.useragents' module is deprecated and will be" + " removed in Werkzeug 2.1. The new base API is" + " 'werkzeug.user_agent.UserAgent'.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(string) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/utils.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/utils.py new file mode 100644 index 00000000..90072314 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/utils.py @@ -0,0 +1,1099 @@ +import codecs +import io +import mimetypes +import os +import pkgutil +import re +import sys +import typing as t +import unicodedata +import warnings +from datetime import datetime +from html.entities import name2codepoint +from time import time +from zlib import adler32 + +from ._internal import _DictAccessorProperty +from ._internal import _missing +from ._internal import _parse_signature +from ._internal import _TAccessorValue +from .datastructures import Headers +from .exceptions import NotFound +from .exceptions import RequestedRangeNotSatisfiable +from .security import safe_join +from .urls import url_quote +from .wsgi import wrap_file + +if t.TYPE_CHECKING: + from _typeshed.wsgi import WSGIEnvironment + from .wrappers.request import Request + from .wrappers.response import Response + +_T = t.TypeVar("_T") + +_entity_re = re.compile(r"&([^;]+);") +_filename_ascii_strip_re = re.compile(r"[^A-Za-z0-9_.-]") +_windows_device_files = ( + "CON", + "AUX", + "COM1", + "COM2", + "COM3", + "COM4", + "LPT1", + "LPT2", + "LPT3", + "PRN", + "NUL", +) + + +class cached_property(property, t.Generic[_T]): + """A :func:`property` that is only evaluated once. Subsequent access + returns the cached value. Setting the property sets the cached + value. Deleting the property clears the cached value, accessing it + again will evaluate it again. + + .. code-block:: python + + class Example: + @cached_property + def value(self): + # calculate something important here + return 42 + + e = Example() + e.value # evaluates + e.value # uses cache + e.value = 16 # sets cache + del e.value # clears cache + + The class must have a ``__dict__`` for this to work. + + .. versionchanged:: 2.0 + ``del obj.name`` clears the cached value. + """ + + def __init__( + self, + fget: t.Callable[[t.Any], _T], + name: t.Optional[str] = None, + doc: t.Optional[str] = None, + ) -> None: + super().__init__(fget, doc=doc) + self.__name__ = name or fget.__name__ + self.__module__ = fget.__module__ + + def __set__(self, obj: object, value: _T) -> None: + obj.__dict__[self.__name__] = value + + def __get__(self, obj: object, type: type = None) -> _T: # type: ignore + if obj is None: + return self # type: ignore + + value: _T = obj.__dict__.get(self.__name__, _missing) + + if value is _missing: + value = self.fget(obj) # type: ignore + obj.__dict__[self.__name__] = value + + return value + + def __delete__(self, obj: object) -> None: + del obj.__dict__[self.__name__] + + +def invalidate_cached_property(obj: object, name: str) -> None: + """Invalidates the cache for a :class:`cached_property`: + + >>> class Test(object): + ... @cached_property + ... def magic_number(self): + ... print("recalculating...") + ... return 42 + ... + >>> var = Test() + >>> var.magic_number + recalculating... + 42 + >>> var.magic_number + 42 + >>> invalidate_cached_property(var, "magic_number") + >>> var.magic_number + recalculating... + 42 + + You must pass the name of the cached property as the second argument. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use ``del obj.name`` instead. + """ + warnings.warn( + "'invalidate_cached_property' is deprecated and will be removed" + " in Werkzeug 2.1. Use 'del obj.name' instead.", + DeprecationWarning, + stacklevel=2, + ) + delattr(obj, name) + + +class environ_property(_DictAccessorProperty[_TAccessorValue]): + """Maps request attributes to environment variables. This works not only + for the Werkzeug request object, but also any other class with an + environ attribute: + + >>> class Test(object): + ... environ = {'key': 'value'} + ... test = environ_property('key') + >>> var = Test() + >>> var.test + 'value' + + If you pass it a second value it's used as default if the key does not + exist, the third one can be a converter that takes a value and converts + it. If it raises :exc:`ValueError` or :exc:`TypeError` the default value + is used. If no default value is provided `None` is used. + + Per default the property is read only. You have to explicitly enable it + by passing ``read_only=False`` to the constructor. + """ + + read_only = True + + def lookup(self, obj: "Request") -> "WSGIEnvironment": + return obj.environ + + +class header_property(_DictAccessorProperty[_TAccessorValue]): + """Like `environ_property` but for headers.""" + + def lookup(self, obj: t.Union["Request", "Response"]) -> Headers: + return obj.headers + + +class HTMLBuilder: + """Helper object for HTML generation. + + Per default there are two instances of that class. The `html` one, and + the `xhtml` one for those two dialects. The class uses keyword parameters + and positional parameters to generate small snippets of HTML. + + Keyword parameters are converted to XML/SGML attributes, positional + arguments are used as children. Because Python accepts positional + arguments before keyword arguments it's a good idea to use a list with the + star-syntax for some children: + + >>> html.p(class_='foo', *[html.a('foo', href='foo.html'), ' ', + ... html.a('bar', href='bar.html')]) + '

    foo bar

    ' + + This class works around some browser limitations and can not be used for + arbitrary SGML/XML generation. For that purpose lxml and similar + libraries exist. + + Calling the builder escapes the string passed: + + >>> html.p(html("")) + '

    <foo>

    ' + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. + """ + + _entity_re = re.compile(r"&([^;]+);") + _entities = name2codepoint.copy() + _entities["apos"] = 39 + _empty_elements = { + "area", + "base", + "basefont", + "br", + "col", + "command", + "embed", + "frame", + "hr", + "img", + "input", + "keygen", + "isindex", + "link", + "meta", + "param", + "source", + "wbr", + } + _boolean_attributes = { + "selected", + "checked", + "compact", + "declare", + "defer", + "disabled", + "ismap", + "multiple", + "nohref", + "noresize", + "noshade", + "nowrap", + } + _plaintext_elements = {"textarea"} + _c_like_cdata = {"script", "style"} + + def __init__(self, dialect): # type: ignore + self._dialect = dialect + + def __call__(self, s): # type: ignore + import html + + warnings.warn( + "'utils.HTMLBuilder' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + return html.escape(s) + + def __getattr__(self, tag): # type: ignore + import html + + warnings.warn( + "'utils.HTMLBuilder' is deprecated and will be removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + if tag[:2] == "__": + raise AttributeError(tag) + + def proxy(*children, **arguments): # type: ignore + buffer = f"<{tag}" + for key, value in arguments.items(): + if value is None: + continue + if key[-1] == "_": + key = key[:-1] + if key in self._boolean_attributes: + if not value: + continue + if self._dialect == "xhtml": + value = f'="{key}"' + else: + value = "" + else: + value = f'="{html.escape(value)}"' + buffer += f" {key}{value}" + if not children and tag in self._empty_elements: + if self._dialect == "xhtml": + buffer += " />" + else: + buffer += ">" + return buffer + buffer += ">" + + children_as_string = "".join([str(x) for x in children if x is not None]) + + if children_as_string: + if tag in self._plaintext_elements: + children_as_string = html.escape(children_as_string) + elif tag in self._c_like_cdata and self._dialect == "xhtml": + children_as_string = f"/**/" + buffer += children_as_string + f"" + return buffer + + return proxy + + def __repr__(self) -> str: + return f"<{type(self).__name__} for {self._dialect!r}>" + + +html = HTMLBuilder("html") +xhtml = HTMLBuilder("xhtml") + +# https://cgit.freedesktop.org/xdg/shared-mime-info/tree/freedesktop.org.xml.in +# https://www.iana.org/assignments/media-types/media-types.xhtml +# Types listed in the XDG mime info that have a charset in the IANA registration. +_charset_mimetypes = { + "application/ecmascript", + "application/javascript", + "application/sql", + "application/xml", + "application/xml-dtd", + "application/xml-external-parsed-entity", +} + + +def get_content_type(mimetype: str, charset: str) -> str: + """Returns the full content type string with charset for a mimetype. + + If the mimetype represents text, the charset parameter will be + appended, otherwise the mimetype is returned unchanged. + + :param mimetype: The mimetype to be used as content type. + :param charset: The charset to be appended for text mimetypes. + :return: The content type. + + .. versionchanged:: 0.15 + Any type that ends with ``+xml`` gets a charset, not just those + that start with ``application/``. Known text types such as + ``application/javascript`` are also given charsets. + """ + if ( + mimetype.startswith("text/") + or mimetype in _charset_mimetypes + or mimetype.endswith("+xml") + ): + mimetype += f"; charset={charset}" + + return mimetype + + +def detect_utf_encoding(data: bytes) -> str: + """Detect which UTF encoding was used to encode the given bytes. + + The latest JSON standard (:rfc:`8259`) suggests that only UTF-8 is + accepted. Older documents allowed 8, 16, or 32. 16 and 32 can be big + or little endian. Some editors or libraries may prepend a BOM. + + :internal: + + :param data: Bytes in unknown UTF encoding. + :return: UTF encoding name + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. This is built in to + :func:`json.loads`. + + .. versionadded:: 0.15 + """ + warnings.warn( + "'detect_utf_encoding' is deprecated and will be removed in" + " Werkzeug 2.1. This is built in to 'json.loads'.", + DeprecationWarning, + stacklevel=2, + ) + head = data[:4] + + if head[:3] == codecs.BOM_UTF8: + return "utf-8-sig" + + if b"\x00" not in head: + return "utf-8" + + if head in (codecs.BOM_UTF32_BE, codecs.BOM_UTF32_LE): + return "utf-32" + + if head[:2] in (codecs.BOM_UTF16_BE, codecs.BOM_UTF16_LE): + return "utf-16" + + if len(head) == 4: + if head[:3] == b"\x00\x00\x00": + return "utf-32-be" + + if head[::2] == b"\x00\x00": + return "utf-16-be" + + if head[1:] == b"\x00\x00\x00": + return "utf-32-le" + + if head[1::2] == b"\x00\x00": + return "utf-16-le" + + if len(head) == 2: + return "utf-16-be" if head.startswith(b"\x00") else "utf-16-le" + + return "utf-8" + + +def format_string(string: str, context: t.Mapping[str, t.Any]) -> str: + """String-template format a string: + + >>> format_string('$foo and ${foo}s', dict(foo=42)) + '42 and 42s' + + This does not do any attribute lookup. + + :param string: the format string. + :param context: a dict with the variables to insert. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :class:`string.Template` + instead. + """ + from string import Template + + warnings.warn( + "'utils.format_string' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'string.Template' instead.", + DeprecationWarning, + stacklevel=2, + ) + return Template(string).substitute(context) + + +def secure_filename(filename: str) -> str: + r"""Pass it a filename and it will return a secure version of it. This + filename can then safely be stored on a regular file system and passed + to :func:`os.path.join`. The filename returned is an ASCII only string + for maximum portability. + + On windows systems the function also makes sure that the file is not + named after one of the special device files. + + >>> secure_filename("My cool movie.mov") + 'My_cool_movie.mov' + >>> secure_filename("../../../etc/passwd") + 'etc_passwd' + >>> secure_filename('i contain cool \xfcml\xe4uts.txt') + 'i_contain_cool_umlauts.txt' + + The function might return an empty filename. It's your responsibility + to ensure that the filename is unique and that you abort or + generate a random filename if the function returned an empty one. + + .. versionadded:: 0.5 + + :param filename: the filename to secure + """ + filename = unicodedata.normalize("NFKD", filename) + filename = filename.encode("ascii", "ignore").decode("ascii") + + for sep in os.path.sep, os.path.altsep: + if sep: + filename = filename.replace(sep, " ") + filename = str(_filename_ascii_strip_re.sub("", "_".join(filename.split()))).strip( + "._" + ) + + # on nt a couple of special files are present in each folder. We + # have to ensure that the target file is not such a filename. In + # this case we prepend an underline + if ( + os.name == "nt" + and filename + and filename.split(".")[0].upper() in _windows_device_files + ): + filename = f"_{filename}" + + return filename + + +def escape(s: t.Any) -> str: + """Replace ``&``, ``<``, ``>``, ``"``, and ``'`` with HTML-safe + sequences. + + ``None`` is escaped to an empty string. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use MarkupSafe instead. + """ + import html + + warnings.warn( + "'utils.escape' is deprecated and will be removed in Werkzeug" + " 2.1. Use MarkupSafe instead.", + DeprecationWarning, + stacklevel=2, + ) + + if s is None: + return "" + + if hasattr(s, "__html__"): + return s.__html__() # type: ignore + + if not isinstance(s, str): + s = str(s) + + return html.escape(s, quote=True) # type: ignore + + +def unescape(s: str) -> str: + """The reverse of :func:`escape`. This unescapes all the HTML + entities, not only those inserted by ``escape``. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use MarkupSafe instead. + """ + import html + + warnings.warn( + "'utils.unescape' is deprecated and will be removed in Werkzueg" + " 2.1. Use MarkupSafe instead.", + DeprecationWarning, + stacklevel=2, + ) + return html.unescape(s) + + +def redirect( + location: str, code: int = 302, Response: t.Optional[t.Type["Response"]] = None +) -> "Response": + """Returns a response object (a WSGI application) that, if called, + redirects the client to the target location. Supported codes are + 301, 302, 303, 305, 307, and 308. 300 is not supported because + it's not a real redirect and 304 because it's the answer for a + request with a request with defined If-Modified-Since headers. + + .. versionadded:: 0.6 + The location can now be a unicode string that is encoded using + the :func:`iri_to_uri` function. + + .. versionadded:: 0.10 + The class used for the Response object can now be passed in. + + :param location: the location the response should redirect to. + :param code: the redirect status code. defaults to 302. + :param class Response: a Response class to use when instantiating a + response. The default is :class:`werkzeug.wrappers.Response` if + unspecified. + """ + import html + + if Response is None: + from .wrappers import Response # type: ignore + + display_location = html.escape(location) + if isinstance(location, str): + # Safe conversion is necessary here as we might redirect + # to a broken URI scheme (for instance itms-services). + from .urls import iri_to_uri + + location = iri_to_uri(location, safe_conversion=True) + response = Response( # type: ignore + '\n' + "Redirecting...\n" + "

    Redirecting...

    \n" + "

    You should be redirected automatically to target URL: " + f'{display_location}. If' + " not click the link.", + code, + mimetype="text/html", + ) + response.headers["Location"] = location + return response + + +def append_slash_redirect(environ: "WSGIEnvironment", code: int = 301) -> "Response": + """Redirects to the same URL but with a slash appended. The behavior + of this function is undefined if the path ends with a slash already. + + :param environ: the WSGI environment for the request that triggers + the redirect. + :param code: the status code for the redirect. + """ + new_path = environ["PATH_INFO"].strip("/") + "/" + query_string = environ.get("QUERY_STRING") + if query_string: + new_path += f"?{query_string}" + return redirect(new_path, code) + + +def send_file( + path_or_file: t.Union[os.PathLike, str, t.IO[bytes]], + environ: "WSGIEnvironment", + mimetype: t.Optional[str] = None, + as_attachment: bool = False, + download_name: t.Optional[str] = None, + conditional: bool = True, + etag: t.Union[bool, str] = True, + last_modified: t.Optional[t.Union[datetime, int, float]] = None, + max_age: t.Optional[ + t.Union[int, t.Callable[[t.Optional[str]], t.Optional[int]]] + ] = None, + use_x_sendfile: bool = False, + response_class: t.Optional[t.Type["Response"]] = None, + _root_path: t.Optional[t.Union[os.PathLike, str]] = None, +) -> "Response": + """Send the contents of a file to the client. + + The first argument can be a file path or a file-like object. Paths + are preferred in most cases because Werkzeug can manage the file and + get extra information from the path. Passing a file-like object + requires that the file is opened in binary mode, and is mostly + useful when building a file in memory with :class:`io.BytesIO`. + + Never pass file paths provided by a user. The path is assumed to be + trusted, so a user could craft a path to access a file you didn't + intend. + + If the WSGI server sets a ``file_wrapper`` in ``environ``, it is + used, otherwise Werkzeug's built-in wrapper is used. Alternatively, + if the HTTP server supports ``X-Sendfile``, ``use_x_sendfile=True`` + will tell the server to send the given path, which is much more + efficient than reading it in Python. + + :param path_or_file: The path to the file to send, relative to the + current working directory if a relative path is given. + Alternatively, a file-like object opened in binary mode. Make + sure the file pointer is seeked to the start of the data. + :param environ: The WSGI environ for the current request. + :param mimetype: The MIME type to send for the file. If not + provided, it will try to detect it from the file name. + :param as_attachment: Indicate to a browser that it should offer to + save the file instead of displaying it. + :param download_name: The default name browsers will use when saving + the file. Defaults to the passed file name. + :param conditional: Enable conditional and range responses based on + request headers. Requires passing a file path and ``environ``. + :param etag: Calculate an ETag for the file, which requires passing + a file path. Can also be a string to use instead. + :param last_modified: The last modified time to send for the file, + in seconds. If not provided, it will try to detect it from the + file path. + :param max_age: How long the client should cache the file, in + seconds. If set, ``Cache-Control`` will be ``public``, otherwise + it will be ``no-cache`` to prefer conditional caching. + :param use_x_sendfile: Set the ``X-Sendfile`` header to let the + server to efficiently send the file. Requires support from the + HTTP server. Requires passing a file path. + :param response_class: Build the response using this class. Defaults + to :class:`~werkzeug.wrappers.Response`. + :param _root_path: Do not use. For internal use only. Use + :func:`send_from_directory` to safely send files under a path. + + .. versionchanged:: 2.0.2 + ``send_file`` only sets a detected ``Content-Encoding`` if + ``as_attachment`` is disabled. + + .. versionadded:: 2.0 + Adapted from Flask's implementation. + + .. versionchanged:: 2.0 + ``download_name`` replaces Flask's ``attachment_filename`` + parameter. If ``as_attachment=False``, it is passed with + ``Content-Disposition: inline`` instead. + + .. versionchanged:: 2.0 + ``max_age`` replaces Flask's ``cache_timeout`` parameter. + ``conditional`` is enabled and ``max_age`` is not set by + default. + + .. versionchanged:: 2.0 + ``etag`` replaces Flask's ``add_etags`` parameter. It can be a + string to use instead of generating one. + + .. versionchanged:: 2.0 + If an encoding is returned when guessing ``mimetype`` from + ``download_name``, set the ``Content-Encoding`` header. + """ + if response_class is None: + from .wrappers import Response + + response_class = Response + + path: t.Optional[str] = None + file: t.Optional[t.IO[bytes]] = None + size: t.Optional[int] = None + mtime: t.Optional[float] = None + headers = Headers() + + if isinstance(path_or_file, (os.PathLike, str)) or hasattr( + path_or_file, "__fspath__" + ): + path_or_file = t.cast(t.Union[os.PathLike, str], path_or_file) + + # Flask will pass app.root_path, allowing its send_file wrapper + # to not have to deal with paths. + if _root_path is not None: + path = os.path.join(_root_path, path_or_file) + else: + path = os.path.abspath(path_or_file) + + stat = os.stat(path) + size = stat.st_size + mtime = stat.st_mtime + else: + file = path_or_file + + if download_name is None and path is not None: + download_name = os.path.basename(path) + + if mimetype is None: + if download_name is None: + raise TypeError( + "Unable to detect the MIME type because a file name is" + " not available. Either set 'download_name', pass a" + " path instead of a file, or set 'mimetype'." + ) + + mimetype, encoding = mimetypes.guess_type(download_name) + + if mimetype is None: + mimetype = "application/octet-stream" + + # Don't send encoding for attachments, it causes browsers to + # save decompress tar.gz files. + if encoding is not None and not as_attachment: + headers.set("Content-Encoding", encoding) + + if download_name is not None: + try: + download_name.encode("ascii") + except UnicodeEncodeError: + simple = unicodedata.normalize("NFKD", download_name) + simple = simple.encode("ascii", "ignore").decode("ascii") + quoted = url_quote(download_name, safe="") + names = {"filename": simple, "filename*": f"UTF-8''{quoted}"} + else: + names = {"filename": download_name} + + value = "attachment" if as_attachment else "inline" + headers.set("Content-Disposition", value, **names) + elif as_attachment: + raise TypeError( + "No name provided for attachment. Either set" + " 'download_name' or pass a path instead of a file." + ) + + if use_x_sendfile and path is not None: + headers["X-Sendfile"] = path + data = None + else: + if file is None: + file = open(path, "rb") # type: ignore + elif isinstance(file, io.BytesIO): + size = file.getbuffer().nbytes + elif isinstance(file, io.TextIOBase): + raise ValueError("Files must be opened in binary mode or use BytesIO.") + + data = wrap_file(environ, file) + + rv = response_class( + data, mimetype=mimetype, headers=headers, direct_passthrough=True + ) + + if size is not None: + rv.content_length = size + + if last_modified is not None: + rv.last_modified = last_modified # type: ignore + elif mtime is not None: + rv.last_modified = mtime # type: ignore + + rv.cache_control.no_cache = True + + # Flask will pass app.get_send_file_max_age, allowing its send_file + # wrapper to not have to deal with paths. + if callable(max_age): + max_age = max_age(path) + + if max_age is not None: + if max_age > 0: + rv.cache_control.no_cache = None + rv.cache_control.public = True + + rv.cache_control.max_age = max_age + rv.expires = int(time() + max_age) # type: ignore + + if isinstance(etag, str): + rv.set_etag(etag) + elif etag and path is not None: + check = adler32(path.encode("utf-8")) & 0xFFFFFFFF + rv.set_etag(f"{mtime}-{size}-{check}") + + if conditional: + try: + rv = rv.make_conditional(environ, accept_ranges=True, complete_length=size) + except RequestedRangeNotSatisfiable: + if file is not None: + file.close() + + raise + + # Some x-sendfile implementations incorrectly ignore the 304 + # status code and send the file anyway. + if rv.status_code == 304: + rv.headers.pop("x-sendfile", None) + + return rv + + +def send_from_directory( + directory: t.Union[os.PathLike, str], + path: t.Union[os.PathLike, str], + environ: "WSGIEnvironment", + **kwargs: t.Any, +) -> "Response": + """Send a file from within a directory using :func:`send_file`. + + This is a secure way to serve files from a folder, such as static + files or uploads. Uses :func:`~werkzeug.security.safe_join` to + ensure the path coming from the client is not maliciously crafted to + point outside the specified directory. + + If the final path does not point to an existing regular file, + returns a 404 :exc:`~werkzeug.exceptions.NotFound` error. + + :param directory: The directory that ``path`` must be located under. + :param path: The path to the file to send, relative to + ``directory``. + :param environ: The WSGI environ for the current request. + :param kwargs: Arguments to pass to :func:`send_file`. + + .. versionadded:: 2.0 + Adapted from Flask's implementation. + """ + path = safe_join(os.fspath(directory), os.fspath(path)) + + if path is None: + raise NotFound() + + # Flask will pass app.root_path, allowing its send_from_directory + # wrapper to not have to deal with paths. + if "_root_path" in kwargs: + path = os.path.join(kwargs["_root_path"], path) + + try: + if not os.path.isfile(path): + raise NotFound() + except ValueError: + # path contains null byte on Python < 3.8 + raise NotFound() from None + + return send_file(path, environ, **kwargs) + + +def import_string(import_name: str, silent: bool = False) -> t.Any: + """Imports an object based on a string. This is useful if you want to + use import paths as endpoints or something similar. An import path can + be specified either in dotted notation (``xml.sax.saxutils.escape``) + or with a colon as object delimiter (``xml.sax.saxutils:escape``). + + If `silent` is True the return value will be `None` if the import fails. + + :param import_name: the dotted name for the object to import. + :param silent: if set to `True` import errors are ignored and + `None` is returned instead. + :return: imported object + """ + import_name = import_name.replace(":", ".") + try: + try: + __import__(import_name) + except ImportError: + if "." not in import_name: + raise + else: + return sys.modules[import_name] + + module_name, obj_name = import_name.rsplit(".", 1) + module = __import__(module_name, globals(), locals(), [obj_name]) + try: + return getattr(module, obj_name) + except AttributeError as e: + raise ImportError(e) from None + + except ImportError as e: + if not silent: + raise ImportStringError(import_name, e).with_traceback( + sys.exc_info()[2] + ) from None + + return None + + +def find_modules( + import_path: str, include_packages: bool = False, recursive: bool = False +) -> t.Iterator[str]: + """Finds all the modules below a package. This can be useful to + automatically import all views / controllers so that their metaclasses / + function decorators have a chance to register themselves on the + application. + + Packages are not returned unless `include_packages` is `True`. This can + also recursively list modules but in that case it will import all the + packages to get the correct load path of that module. + + :param import_path: the dotted name for the package to find child modules. + :param include_packages: set to `True` if packages should be returned, too. + :param recursive: set to `True` if recursion should happen. + :return: generator + """ + module = import_string(import_path) + path = getattr(module, "__path__", None) + if path is None: + raise ValueError(f"{import_path!r} is not a package") + basename = f"{module.__name__}." + for _importer, modname, ispkg in pkgutil.iter_modules(path): + modname = basename + modname + if ispkg: + if include_packages: + yield modname + if recursive: + yield from find_modules(modname, include_packages, True) + else: + yield modname + + +def validate_arguments(func, args, kwargs, drop_extra=True): # type: ignore + """Checks if the function accepts the arguments and keyword arguments. + Returns a new ``(args, kwargs)`` tuple that can safely be passed to + the function without causing a `TypeError` because the function signature + is incompatible. If `drop_extra` is set to `True` (which is the default) + any extra positional or keyword arguments are dropped automatically. + + The exception raised provides three attributes: + + `missing` + A set of argument names that the function expected but where + missing. + + `extra` + A dict of keyword arguments that the function can not handle but + where provided. + + `extra_positional` + A list of values that where given by positional argument but the + function cannot accept. + + This can be useful for decorators that forward user submitted data to + a view function:: + + from werkzeug.utils import ArgumentValidationError, validate_arguments + + def sanitize(f): + def proxy(request): + data = request.values.to_dict() + try: + args, kwargs = validate_arguments(f, (request,), data) + except ArgumentValidationError: + raise BadRequest('The browser failed to transmit all ' + 'the data expected.') + return f(*args, **kwargs) + return proxy + + :param func: the function the validation is performed against. + :param args: a tuple of positional arguments. + :param kwargs: a dict of keyword arguments. + :param drop_extra: set to `False` if you don't want extra arguments + to be silently dropped. + :return: tuple in the form ``(args, kwargs)``. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :func:`inspect.signature` + instead. + """ + warnings.warn( + "'utils.validate_arguments' is deprecated and will be removed" + " in Werkzeug 2.1. Use 'inspect.signature' instead.", + DeprecationWarning, + stacklevel=2, + ) + parser = _parse_signature(func) + args, kwargs, missing, extra, extra_positional = parser(args, kwargs)[:5] + if missing: + raise ArgumentValidationError(tuple(missing)) + elif (extra or extra_positional) and not drop_extra: + raise ArgumentValidationError(None, extra, extra_positional) + return tuple(args), kwargs + + +def bind_arguments(func, args, kwargs): # type: ignore + """Bind the arguments provided into a dict. When passed a function, + a tuple of arguments and a dict of keyword arguments `bind_arguments` + returns a dict of names as the function would see it. This can be useful + to implement a cache decorator that uses the function arguments to build + the cache key based on the values of the arguments. + + :param func: the function the arguments should be bound for. + :param args: tuple of positional arguments. + :param kwargs: a dict of keyword arguments. + :return: a :class:`dict` of bound keyword arguments. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Use :meth:`Signature.bind` + instead. + """ + warnings.warn( + "'utils.bind_arguments' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'Signature.bind' instead.", + DeprecationWarning, + stacklevel=2, + ) + ( + args, + kwargs, + missing, + extra, + extra_positional, + arg_spec, + vararg_var, + kwarg_var, + ) = _parse_signature(func)(args, kwargs) + values = {} + for (name, _has_default, _default), value in zip(arg_spec, args): + values[name] = value + if vararg_var is not None: + values[vararg_var] = tuple(extra_positional) + elif extra_positional: + raise TypeError("too many positional arguments") + if kwarg_var is not None: + multikw = set(extra) & {x[0] for x in arg_spec} + if multikw: + raise TypeError( + f"got multiple values for keyword argument {next(iter(multikw))!r}" + ) + values[kwarg_var] = extra + elif extra: + raise TypeError(f"got unexpected keyword argument {next(iter(extra))!r}") + return values + + +class ArgumentValidationError(ValueError): + """Raised if :func:`validate_arguments` fails to validate + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1 along with ``utils.bind`` and + ``validate_arguments``. + """ + + def __init__(self, missing=None, extra=None, extra_positional=None): # type: ignore + self.missing = set(missing or ()) + self.extra = extra or {} + self.extra_positional = extra_positional or [] + super().__init__( + "function arguments invalid." + f" ({len(self.missing)} missing," + f" {len(self.extra) + len(self.extra_positional)} additional)" + ) + + +class ImportStringError(ImportError): + """Provides information about a failed :func:`import_string` attempt.""" + + #: String in dotted notation that failed to be imported. + import_name: str + #: Wrapped exception. + exception: BaseException + + def __init__(self, import_name: str, exception: BaseException) -> None: + self.import_name = import_name + self.exception = exception + msg = import_name + name = "" + tracked = [] + for part in import_name.replace(":", ".").split("."): + name = f"{name}.{part}" if name else part + imported = import_string(name, silent=True) + if imported: + tracked.append((name, getattr(imported, "__file__", None))) + else: + track = [f"- {n!r} found in {i!r}." for n, i in tracked] + track.append(f"- {name!r} not found.") + track_str = "\n".join(track) + msg = ( + f"import_string() failed for {import_name!r}. Possible reasons" + f" are:\n\n" + "- missing __init__.py in a package;\n" + "- package or module path not included in sys.path;\n" + "- duplicated package or module name taking precedence in" + " sys.path;\n" + "- missing module, class, function or variable;\n\n" + f"Debugged import:\n\n{track_str}\n\n" + f"Original exception:\n\n{type(exception).__name__}: {exception}" + ) + break + + super().__init__(msg) + + def __repr__(self) -> str: + return f"<{type(self).__name__}({self.import_name!r}, {self.exception!r})>" diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__init__.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__init__.py new file mode 100644 index 00000000..eb69a994 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__init__.py @@ -0,0 +1,16 @@ +from .accept import AcceptMixin +from .auth import AuthorizationMixin +from .auth import WWWAuthenticateMixin +from .base_request import BaseRequest +from .base_response import BaseResponse +from .common_descriptors import CommonRequestDescriptorsMixin +from .common_descriptors import CommonResponseDescriptorsMixin +from .etag import ETagRequestMixin +from .etag import ETagResponseMixin +from .request import PlainRequest +from .request import Request as Request +from .request import StreamOnlyMixin +from .response import Response as Response +from .response import ResponseStream +from .response import ResponseStreamMixin +from .user_agent import UserAgentMixin diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/__init__.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/__init__.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..6123a72455112569cb71b78c11839dbf1273926b GIT binary patch literal 879 zcmaKq%We}f6ozM#NixY?a%oz^g6^}RU35iNAwprtO)V&r6=~#7tih^1GuWP%@t~mC@6eNU4bM&3x=lA8vIEn@ijGuQ~{H5hM-*xim0L^&@zx)Pa?W|qq za2L6*<`!%5HfkGg1AE9b?6D5-qORc%>v13XhP$lK2WVip2OOZlu+Kssp~!F_I7YGI z0UPoW8W|3N$7pOg1fHOY;fU?=DViFNf%nnA;UVw=Ixsw95BLntfXA24eDcGEtIXXx zSfnW_)oc2h=8#SnmHJo+y2XkXxmBmjb%7 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/accept.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/accept.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..00a9f984b38498464acb42f7511f0b84c20c1a0c GIT binary patch literal 785 zcmYjPO>Yx15VhBvbSVvAg1g0mC`hCNP9TJ+gv14MfJ3DylI5k6g$iMOwli-lV9OI(koNkwtQ3grfc1A||Db?gO`$d0Hikl_wy`^t&O>1-Qxq`|;DFY}jt>SZS3_k+yU^1QI zH*NVLxbYI|A%D?*-sSDja8iR0ZEmM?Y?r21;Cc88{J6Gd&{Hdo4hya{;s&$mUS&wJ zL*uRwvK$+jfx)#4+|O!@tL7<-58iKxAi&|e6&t>;z{NrcZFLYLspG*MyQF|il3&tz zONi1)?}fM|*9YqLU});0fkCyHft|hVz8ZYgM+2_|JgacN9D*OrH!JPWovd(#-2KjvkrGsc0YxrS$boil7g=4P9B?KQK4w=QMyy4kosE)E3AYNi#Ka3 NZ_}^ilUM~U*ngF;%(4Ig literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/auth.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/auth.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..7c9ee55c59f7a8fb43090bbbbd4208f6b949d55d GIT binary patch literal 1263 zcmb_c&2AGh5VrRxT}n!!DjYzSd?Esgl%Ep_0hN%rKo4*TiXvI=+D)Ch&erxOBr2y? z>It5JBbUC?UODvLgusEX7c5UQn_o$+XA=9~F;#nRFuf%E%pEI!AC{6c5`z#Vx5 z;va*OL{dZAbn=Ya(K{j|86OcDA4csMyhNtprQju!ej*QQr|=fp%u&yuWajvXV5mvP zcBJB7f+DGme#FOQo61-wNA-4kOcK(rLB6zF*(k$K-|4Xkx^F+|FWPRN#8o0(*H^XO z;q>WLD4oseTulU$f-Hmh`=A2pQAtCD5WdBfg!qv3k^`#ALG+V;rxf5q$z*dpZd@$d zVA?aO3a4@rlw`t6Hq^$jEybML>kr^gTh>x;cdW`Td)j=`WQ~t%zf?XnnC%ZCoSRZA z&%%yk+ojDBkuW-pnADIrm{IdIf=*9pwdjM$ca0h-bCOmWz_i)|;smW~L27qF6MF>*NC8i=ohA~c~<9MR}cZDD-x;sBfHjV)l4 zR_rOxt3}TD`m!`=*E!!Wg_%WYsNxMfEmAGb`p%UxoV!&hH&rWW-A09jLzEtkj86P3 z@U_cYKVP}KgUK%2+8P9IVaD0k(1)+S7Dff|-QC6auA{=Z!{}U^^Tw*|<&;IQ O@DJdTlNrt88}+{}7(65Z literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_request.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_request.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..731c8a793fd39d7ec41db5d01f47352c279dc2b2 GIT binary patch literal 1738 zcmd5+&2Jnv6t`zQADbr7MkyemXoL{yBG^JXfeZu$#_1H`QC0~2WpFruM@6FCOTY?Z07cBWV<7fMQ_`ToDwzf7Hjz3;3vfl+` z&uOtfLR{R!Y40E?rnqJ)Z@ymYDNp&@AB$9Qc9$ukf>Wjf2u}Po#C515Tt^@vRPkex zMvC8O-Od?mVtZ#CvCCcbGd!%pRyj%6hmVU}IPI4R&{$19@DBw9ia%*=pNcd@NrV!C zl0bzhiB*JFVz(`S%0_U%9^^W+_Vxkfqps&-+X`H0psG!od#HXj=s&=D8>f9Ap<;(z z@v5=**ypVBk9j3dJhUM876-dOW)|82c9X&;3Z@3~tOAu}rAlUn*2w@81LMgN%8D|1 z0A{p+dYIhoebq~TwUF!W zrhl&(^leeW7gMyD4Z-$jt>-spCYw&d*c$_kUYce8degbPBIPQQoZef?81>st1jYsT zJdb-X!*KD*#nkjJT%}}D{8^cUp)&kmWNPKn^~vDy?=oc~^wdz;-M|pF%q0SP0?Nhe zdYcRL7Hw`5P$rgena<)3iTQS?kzC+1?b5KHA-ut5c7~K!)iXoZne}-)NoPTI~q1Pf&0+ZPjh{Z5sk5i7V&q>(*2&2Zi!|wkG)O*^3E&f C?XuGV literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_response.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/base_response.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..47255053ad02d54563ec0b2611578b821d76bc39 GIT binary patch literal 1749 zcmd5+&5zqe6rZujjGD5#PZY2Hs)K4GcObt^XK=qBXF9d^?nB6C1J6ZvD{!HKsy0RD;q&dF{{ZJ*oc1+@icPuV zRio{(&spW4@JgI|s6iaAr~NNd3#|wJIJdEa(mk3CmKfO>KKaSkA@$Q zzRAZUn^$nFM2+bL>}a_){r1wNWeLXK9;5%#Y*RQaSMI8mtuGmcT*?R)*d7Aof_t9F zz2C!d{m$j=3@=@!d{F?>A_GIE`2R>&YtoIyc>1@=G99$lkmG~E5W&m~1QY~HM|*#p z4)Y>y9uQD6HgJW`VldmY+hATr@xKk`U#=bwx-OEkNarA>+mmv>P_?H2o|He-sow7J z%8Bn*B{(r&EVLnw&i}kvnQMO<_q>?~8wVqgE&W9Npxa0;5t?>s*!K{gBQ%m)apgVn zAF(5@d?n6$N$`jXmV`*O!1Z=%b~x~zNDbC}IK!f!*iB_nKWPV*Ih8lrY2QV-Oyg5F z6(>ArC*IHeN6xXgZ75y;cS`qL`u5{uu|x)Ex>jK0>LJ8Ob&*v_&Q#~sDpoo6ib}7B z|5Px6t&wV!y1d9MDam~c`pCSAj+wU*uq||@Y}%ZZ7v*DO+jW`^+uv%*Km=?8MZaSUIP^%V8&3Tnqb07Fz6 zJD%{j0~AiV_uW4vTa^1eIB0glLlTfq1M-FC(wnT`&-8n-TL|k`g-wmjU1sc>{3P}I zkzWRh>DjWeGo0*3xWed^&Xh+?A;@(Qy9~;aZOWw;UJyrCS=;ot= z(1WM#XWe&lvumXj4|AxW^n~pWYe*|YljKmsuB6qV7(h84Q9BL~g3o1|4 zB3idmVMh_ZMI)k>e~GlccM8ttnYQ8#Zw+$tvPgP3CF%Lq{+FebZ2wMEGY6ndgbE)S za|2b?@@fKA-;ob^be0c)0Wl?nxr1rXo9Pk+Zes3wrs%^H(r}|3eiL&Szq^VG;|8NM YX{J{!qZbp7y~H=fB6%Yk`PZ6%0M2P$4gdfE literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/cors.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/cors.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..59881c6b20e5e093e78d63c0c3050e6b8b658448 GIT binary patch literal 1248 zcmb_cOKTKC5bmCy*^F_cNl?LnFeeuUH$F~^_&~vnu8Zx(5|uFwX_SF^L$u1}_jMzXV516^ zkt=d(%b0Uzl;<2Fa#C+u#N8qekoFqqnNFR9FgbfIUiA99=xf=_$3tm`&)Uy>AJt~h zDK8)8P(STU*BjL%t&VJ(LkYK<4XkVDV~fBxKwJ|Pp&<=eK!e|nxyjv&@U_p|n!^@N zx+^&^=Q-aUh(e>?xn z;8Hb@%Lm5Eih>sDbya+u)O?#M@V|tsQv5sP>>SKtV^sK8u#2dsz)o?VqKk{htILaC zxdhDlrtKZf^tWZ*gTNA|tCxj7eC7>5&Vl511>d`l3gZ@|GilDdD&vJM=$wHbM=&;V7yqhGlV7aAd-fvsp?|t@zpoOmzEX@oL{F?-U$i$iO&3iJMs#| zJp?6)pqg~)>=|@}cSHmtJR~AK2)ZG7k%+;I!HWd_MD8_C;4RY0P|u&JcHDh14vo1Q(5%W$L&Y$v{g6VO3iQ#;Y=4oy3~J> z=~iJfuZD(eE+JkPeZ97%l~mkA7Ml!198w93^tbt8~qqY9O= zD{^VegfV55XAB{7Qg2zr-69T<_6lQ}=FUNwoW2y#dVO8=we01Sku;+x?Weu>YP08* zmk)BN&->E##`Q?+W6N_W;nt<+{dPXF2y6qyH9-*?(I5DlXpvr*#kXnAx48oUOSme~!!WJ~? literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/json.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/json.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..100f5fbd1b0742fe4abf4ca58099a3c017c11fa9 GIT binary patch literal 777 zcmYjP&x;c=6izbJakjMnSnwV^SSmP+dQ!w6APAxr+{4092(y#4rcKjnl4)((+b--$ z{{ZpmW&fpIJ?)?1;=z};ls9OPJTs~Xn=Xd z9zwr-@VXmOOx0-c!y*gA{%0*>FSvbLIp*dYhrRb@kMogx2 z_$D|)=vt|-S!%!PuHQJ7JVZ{?OkDaOoQ=(2&^A-WeJ>?{0T8-f(C^KR@Dx2#}c=6<-71_<>%hBa4U@afBq Olvm-=*s!P+r_p~O=g6J_ literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/request.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/request.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..fa7979e794e2d25f7fd2dbe6232f5b810fa3e396 GIT binary patch literal 21276 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%0AwEc7 zi2D>3(NuzzDZM_Ozw-k>?OTo{Lb+@1Eo@)GENYZ=*Wh~vuH-04)by#{jc#yLPauS#V|g@d*s~x{Ca0yW%Si}Z;(g# ziy{tR=IAHzIET?=s}5PvmM*ta=m6^!^9EjwjTFN-l>9M6+S9{5gld^c51S0R$MpPtYCw?jZv5~bNfVDiT*xo z`v*MyCJy}q;#cY?L_~K`TeSQ(ACnfM-{RpP@$e%aM6CZl&;BV7f55{Z^6)QtAY7w= z$3sdna^~?KgRW=TQAVziLt2FEw=iAaUzo~I6{d<)1y==T>v%ly;k@w^KZJu3Zef0{ zz%PSP@8sq8eX!Z+n-i6y{4z?3OshXM0U|vREbSMNXc6~ISMe)Xt2_Me6FMnr%Cs_K zs@w^kuu!vwYvzG6dF-qVp4k8s`L^>m*ocr&VX?P)bdXO=lSio=|BS1uJX_IGsO8ro zwd&0-w=bvUGHVOeCX7bFsb3I_WNlM1x*PqLHA~SAo}J`@V#Tnxf6p8Lfd|o+(s^Pb zMmaS1MW{XxwdN;SpoEx*5{e3+Wo%Xu!OWsEoWU=_ogea^RQa!XmLi6<>hazm;qV3< zBnFoqxt=?z^ud3@0#Xsj(=YJX_LTlRiVbg}IwSc|^1>@qbfm^Mb6#niWD-nt#}ea? z{lyJYp(?womvQ^TOJ+>{0)Fu?mLzYL!d;YKLJ>W*QlKw18fRxHlPWXF442$EayA4pHdG7)2yN`bOY$^A0rq~<-i*PmSa(#vP7r_Y}~{lbOC=PSFFR*rR_Sk}V* zQ(`O(4J%W!Tojs2FfXs}WySk=AYCb1y^m-AkOv{jS)Tn44@71~x)1YA@*oKQ%)D4c y=$D^XsUOJk!Q?FBK!uq9CR}c~^D+Nq7bbb0pPAlEMR)AZvFTsPrT@xP$Nx7{sq8!e literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/user_agent.cpython-39.pyc b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/__pycache__/user_agent.cpython-39.pyc new file mode 100644 index 0000000000000000000000000000000000000000..9e39b6b50b57f5d3957d7a2a918d495376ec7bb7 GIT binary patch literal 798 zcmY*XO>Yx15VhBvbcvGkAtA072cjU63OIofq7sM;g6DSwPNmQjH&3IYJBDcoaBV1?07fQ{4WlFH;KJ10Xb znM}``{n|N6NxzPGwXplef!!a0@gLPUWqKVJ(%g<*s2|POrv+bGQy~3oi?nO#x6$1r z44#asq&|s+zcWfaJ0;`vger29{GvZ7#pNRX-g4HyIk3%@;}S{>MeafJ+(yLR_yG z-OB`7c4%lgpBG0OW}tET3|BPD;I?VZ!o9Z}A_#D>ZiSkwO0XdlLK)?Shypp#LmNe~ zQTPiQZV6H7+&LjG$kjXfaxl`>NW-99%)rc^cV7%XsKbF%9-fpqKOcb`%r`6T&23)d z2)9?^QwZ!C-z^umiO_X)7ZXBLny`c>|LQx-2R9|`UQ^qNG)+DMAwoll$y8Q4=1n1v zt6Xn7)Cab2)&oLo!@K~kg|K&U)H>|O>~0KEy7<~ICK+AToix<_qD1ZN{dgyfA@;Wr VR#*`sWUtm#UdNxvMa?prvH$oK(mVhF literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/accept.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/accept.py new file mode 100644 index 00000000..9605e637 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/accept.py @@ -0,0 +1,14 @@ +import typing as t +import warnings + + +class AcceptMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'AcceptMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/auth.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/auth.py new file mode 100644 index 00000000..da31b7cf --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/auth.py @@ -0,0 +1,26 @@ +import typing as t +import warnings + + +class AuthorizationMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'AuthorizationMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore + + +class WWWAuthenticateMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'WWWAuthenticateMixin' is deprecated and will be removed" + " in Werkzeug 2.1. 'Response' now includes the" + " functionality directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_request.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_request.py new file mode 100644 index 00000000..451989fd --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_request.py @@ -0,0 +1,36 @@ +import typing as t +import warnings + +from .request import Request + + +class _FakeSubclassCheck(type): + def __subclasscheck__(cls, subclass: t.Type) -> bool: + warnings.warn( + "'BaseRequest' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'issubclass(cls, Request)' instead.", + DeprecationWarning, + stacklevel=2, + ) + return issubclass(subclass, Request) + + def __instancecheck__(cls, instance: t.Any) -> bool: + warnings.warn( + "'BaseRequest' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'isinstance(obj, Request)' instead.", + DeprecationWarning, + stacklevel=2, + ) + return isinstance(instance, Request) + + +class BaseRequest(Request, metaclass=_FakeSubclassCheck): + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'BaseRequest' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_response.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_response.py new file mode 100644 index 00000000..3e0dc676 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/base_response.py @@ -0,0 +1,36 @@ +import typing as t +import warnings + +from .response import Response + + +class _FakeSubclassCheck(type): + def __subclasscheck__(cls, subclass: t.Type) -> bool: + warnings.warn( + "'BaseResponse' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'issubclass(cls, Response)' instead.", + DeprecationWarning, + stacklevel=2, + ) + return issubclass(subclass, Response) + + def __instancecheck__(cls, instance: t.Any) -> bool: + warnings.warn( + "'BaseResponse' is deprecated and will be removed in" + " Werkzeug 2.1. Use 'isinstance(obj, Response)' instead.", + DeprecationWarning, + stacklevel=2, + ) + return isinstance(instance, Response) + + +class BaseResponse(Response, metaclass=_FakeSubclassCheck): + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'BaseResponse' is deprecated and will be removed in" + " Werkzeug 2.1. 'Response' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/common_descriptors.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/common_descriptors.py new file mode 100644 index 00000000..db87ea5f --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/common_descriptors.py @@ -0,0 +1,26 @@ +import typing as t +import warnings + + +class CommonRequestDescriptorsMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'CommonRequestDescriptorsMixin' is deprecated and will be" + " removed in Werkzeug 2.1. 'Request' now includes the" + " functionality directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore + + +class CommonResponseDescriptorsMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'CommonResponseDescriptorsMixin' is deprecated and will be" + " removed in Werkzeug 2.1. 'Response' now includes the" + " functionality directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/cors.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/cors.py new file mode 100644 index 00000000..89cf83ef --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/cors.py @@ -0,0 +1,26 @@ +import typing as t +import warnings + + +class CORSRequestMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'CORSRequestMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore + + +class CORSResponseMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'CORSResponseMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Response' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/etag.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/etag.py new file mode 100644 index 00000000..2e9015a5 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/etag.py @@ -0,0 +1,26 @@ +import typing as t +import warnings + + +class ETagRequestMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'ETagRequestMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore + + +class ETagResponseMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'ETagResponseMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Response' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/json.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/json.py new file mode 100644 index 00000000..ab6ed7ba --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/json.py @@ -0,0 +1,13 @@ +import typing as t +import warnings + + +class JSONMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'JSONMixin' is deprecated and will be removed in Werkzeug" + " 2.1. 'Request' now includes the functionality directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/request.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/request.py new file mode 100644 index 00000000..700cda04 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/request.py @@ -0,0 +1,660 @@ +import functools +import json +import typing +import typing as t +import warnings +from io import BytesIO + +from .._internal import _wsgi_decoding_dance +from ..datastructures import CombinedMultiDict +from ..datastructures import EnvironHeaders +from ..datastructures import FileStorage +from ..datastructures import ImmutableMultiDict +from ..datastructures import iter_multi_items +from ..datastructures import MultiDict +from ..formparser import default_stream_factory +from ..formparser import FormDataParser +from ..sansio.request import Request as _SansIORequest +from ..utils import cached_property +from ..utils import environ_property +from ..wsgi import _get_server +from ..wsgi import get_input_stream +from werkzeug.exceptions import BadRequest + +if t.TYPE_CHECKING: + import typing_extensions as te + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +class Request(_SansIORequest): + """Represents an incoming WSGI HTTP request, with headers and body + taken from the WSGI environment. Has properties and methods for + using the functionality defined by various HTTP specs. The data in + requests object is read-only. + + Text data is assumed to use UTF-8 encoding, which should be true for + the vast majority of modern clients. Using an encoding set by the + client is unsafe in Python due to extra encodings it provides, such + as ``zip``. To change the assumed encoding, subclass and replace + :attr:`charset`. + + :param environ: The WSGI environ is generated by the WSGI server and + contains information about the server configuration and client + request. + :param populate_request: Add this request object to the WSGI environ + as ``environ['werkzeug.request']``. Can be useful when + debugging. + :param shallow: Makes reading from :attr:`stream` (and any method + that would read from it) raise a :exc:`RuntimeError`. Useful to + prevent consuming the form data in middleware, which would make + it unavailable to the final application. + + .. versionchanged:: 2.0 + Combine ``BaseRequest`` and mixins into a single ``Request`` + class. Using the old classes is deprecated and will be removed + in Werkzeug 2.1. + + .. versionchanged:: 0.5 + Read-only mode is enforced with immutable classes for all data. + """ + + #: the maximum content length. This is forwarded to the form data + #: parsing function (:func:`parse_form_data`). When set and the + #: :attr:`form` or :attr:`files` attribute is accessed and the + #: parsing fails because more than the specified value is transmitted + #: a :exc:`~werkzeug.exceptions.RequestEntityTooLarge` exception is raised. + #: + #: Have a look at :doc:`/request_data` for more details. + #: + #: .. versionadded:: 0.5 + max_content_length: t.Optional[int] = None + + #: the maximum form field size. This is forwarded to the form data + #: parsing function (:func:`parse_form_data`). When set and the + #: :attr:`form` or :attr:`files` attribute is accessed and the + #: data in memory for post data is longer than the specified value a + #: :exc:`~werkzeug.exceptions.RequestEntityTooLarge` exception is raised. + #: + #: Have a look at :doc:`/request_data` for more details. + #: + #: .. versionadded:: 0.5 + max_form_memory_size: t.Optional[int] = None + + #: The form data parser that shoud be used. Can be replaced to customize + #: the form date parsing. + form_data_parser_class: t.Type[FormDataParser] = FormDataParser + + #: Disable the :attr:`data` property to avoid reading from the input + #: stream. + #: + #: .. deprecated:: 2.0 + #: Will be removed in Werkzeug 2.1. Create the request with + #: ``shallow=True`` instead. + #: + #: .. versionadded:: 0.9 + disable_data_descriptor: t.Optional[bool] = None + + #: The WSGI environment containing HTTP headers and information from + #: the WSGI server. + environ: "WSGIEnvironment" + + #: Set when creating the request object. If ``True``, reading from + #: the request body will cause a ``RuntimeException``. Useful to + #: prevent modifying the stream from middleware. + shallow: bool + + def __init__( + self, + environ: "WSGIEnvironment", + populate_request: bool = True, + shallow: bool = False, + ) -> None: + super().__init__( + method=environ.get("REQUEST_METHOD", "GET"), + scheme=environ.get("wsgi.url_scheme", "http"), + server=_get_server(environ), + root_path=_wsgi_decoding_dance( + environ.get("SCRIPT_NAME") or "", self.charset, self.encoding_errors + ), + path=_wsgi_decoding_dance( + environ.get("PATH_INFO") or "", self.charset, self.encoding_errors + ), + query_string=environ.get("QUERY_STRING", "").encode("latin1"), + headers=EnvironHeaders(environ), + remote_addr=environ.get("REMOTE_ADDR"), + ) + self.environ = environ + + if self.disable_data_descriptor is not None: + warnings.warn( + "'disable_data_descriptor' is deprecated and will be" + " removed in Werkzeug 2.1. Create the request with" + " 'shallow=True' instead.", + DeprecationWarning, + stacklevel=2, + ) + shallow = shallow or self.disable_data_descriptor + + self.shallow = shallow + + if populate_request and not shallow: + self.environ["werkzeug.request"] = self + + @classmethod + def from_values(cls, *args: t.Any, **kwargs: t.Any) -> "Request": + """Create a new request object based on the values provided. If + environ is given missing values are filled from there. This method is + useful for small scripts when you need to simulate a request from an URL. + Do not use this method for unittesting, there is a full featured client + object (:class:`Client`) that allows to create multipart requests, + support for cookies etc. + + This accepts the same options as the + :class:`~werkzeug.test.EnvironBuilder`. + + .. versionchanged:: 0.5 + This method now accepts the same arguments as + :class:`~werkzeug.test.EnvironBuilder`. Because of this the + `environ` parameter is now called `environ_overrides`. + + :return: request object + """ + from ..test import EnvironBuilder + + charset = kwargs.pop("charset", cls.charset) + kwargs["charset"] = charset + builder = EnvironBuilder(*args, **kwargs) + try: + return builder.get_request(cls) + finally: + builder.close() + + @classmethod + def application( + cls, f: t.Callable[["Request"], "WSGIApplication"] + ) -> "WSGIApplication": + """Decorate a function as responder that accepts the request as + the last argument. This works like the :func:`responder` + decorator but the function is passed the request object as the + last argument and the request object will be closed + automatically:: + + @Request.application + def my_wsgi_app(request): + return Response('Hello World!') + + As of Werkzeug 0.14 HTTP exceptions are automatically caught and + converted to responses instead of failing. + + :param f: the WSGI callable to decorate + :return: a new WSGI callable + """ + #: return a callable that wraps the -2nd argument with the request + #: and calls the function with all the arguments up to that one and + #: the request. The return value is then called with the latest + #: two arguments. This makes it possible to use this decorator for + #: both standalone WSGI functions as well as bound methods and + #: partially applied functions. + from ..exceptions import HTTPException + + @functools.wraps(f) + def application(*args): # type: ignore + request = cls(args[-2]) + with request: + try: + resp = f(*args[:-2] + (request,)) + except HTTPException as e: + resp = e.get_response(args[-2]) + return resp(*args[-2:]) + + return t.cast("WSGIApplication", application) + + def _get_file_stream( + self, + total_content_length: t.Optional[int], + content_type: t.Optional[str], + filename: t.Optional[str] = None, + content_length: t.Optional[int] = None, + ) -> t.IO[bytes]: + """Called to get a stream for the file upload. + + This must provide a file-like class with `read()`, `readline()` + and `seek()` methods that is both writeable and readable. + + The default implementation returns a temporary file if the total + content length is higher than 500KB. Because many browsers do not + provide a content length for the files only the total content + length matters. + + :param total_content_length: the total content length of all the + data in the request combined. This value + is guaranteed to be there. + :param content_type: the mimetype of the uploaded file. + :param filename: the filename of the uploaded file. May be `None`. + :param content_length: the length of this file. This value is usually + not provided because webbrowsers do not provide + this value. + """ + return default_stream_factory( + total_content_length=total_content_length, + filename=filename, + content_type=content_type, + content_length=content_length, + ) + + @property + def want_form_data_parsed(self) -> bool: + """``True`` if the request method carries content. By default + this is true if a ``Content-Type`` is sent. + + .. versionadded:: 0.8 + """ + return bool(self.environ.get("CONTENT_TYPE")) + + def make_form_data_parser(self) -> FormDataParser: + """Creates the form data parser. Instantiates the + :attr:`form_data_parser_class` with some parameters. + + .. versionadded:: 0.8 + """ + return self.form_data_parser_class( + self._get_file_stream, + self.charset, + self.encoding_errors, + self.max_form_memory_size, + self.max_content_length, + self.parameter_storage_class, + ) + + def _load_form_data(self) -> None: + """Method used internally to retrieve submitted data. After calling + this sets `form` and `files` on the request object to multi dicts + filled with the incoming form data. As a matter of fact the input + stream will be empty afterwards. You can also call this method to + force the parsing of the form data. + + .. versionadded:: 0.8 + """ + # abort early if we have already consumed the stream + if "form" in self.__dict__: + return + + if self.want_form_data_parsed: + parser = self.make_form_data_parser() + data = parser.parse( + self._get_stream_for_parsing(), + self.mimetype, + self.content_length, + self.mimetype_params, + ) + else: + data = ( + self.stream, + self.parameter_storage_class(), + self.parameter_storage_class(), + ) + + # inject the values into the instance dict so that we bypass + # our cached_property non-data descriptor. + d = self.__dict__ + d["stream"], d["form"], d["files"] = data + + def _get_stream_for_parsing(self) -> t.IO[bytes]: + """This is the same as accessing :attr:`stream` with the difference + that if it finds cached data from calling :meth:`get_data` first it + will create a new stream out of the cached data. + + .. versionadded:: 0.9.3 + """ + cached_data = getattr(self, "_cached_data", None) + if cached_data is not None: + return BytesIO(cached_data) + return self.stream + + def close(self) -> None: + """Closes associated resources of this request object. This + closes all file handles explicitly. You can also use the request + object in a with statement which will automatically close it. + + .. versionadded:: 0.9 + """ + files = self.__dict__.get("files") + for _key, value in iter_multi_items(files or ()): + value.close() + + def __enter__(self) -> "Request": + return self + + def __exit__(self, exc_type, exc_value, tb) -> None: # type: ignore + self.close() + + @cached_property + def stream(self) -> t.IO[bytes]: + """ + If the incoming form data was not encoded with a known mimetype + the data is stored unmodified in this stream for consumption. Most + of the time it is a better idea to use :attr:`data` which will give + you that data as a string. The stream only returns the data once. + + Unlike :attr:`input_stream` this stream is properly guarded that you + can't accidentally read past the length of the input. Werkzeug will + internally always refer to this stream to read data which makes it + possible to wrap this object with a stream that does filtering. + + .. versionchanged:: 0.9 + This stream is now always available but might be consumed by the + form parser later on. Previously the stream was only set if no + parsing happened. + """ + if self.shallow: + raise RuntimeError( + "This request was created with 'shallow=True', reading" + " from the input stream is disabled." + ) + + return get_input_stream(self.environ) + + input_stream = environ_property[t.IO[bytes]]( + "wsgi.input", + doc="""The WSGI input stream. + + In general it's a bad idea to use this one because you can + easily read past the boundary. Use the :attr:`stream` + instead.""", + ) + + @cached_property + def data(self) -> bytes: + """ + Contains the incoming request data as string in case it came with + a mimetype Werkzeug does not handle. + """ + return self.get_data(parse_form_data=True) + + @typing.overload + def get_data( # type: ignore + self, + cache: bool = True, + as_text: "te.Literal[False]" = False, + parse_form_data: bool = False, + ) -> bytes: + ... + + @typing.overload + def get_data( + self, + cache: bool = True, + as_text: "te.Literal[True]" = ..., + parse_form_data: bool = False, + ) -> str: + ... + + def get_data( + self, cache: bool = True, as_text: bool = False, parse_form_data: bool = False + ) -> t.Union[bytes, str]: + """This reads the buffered incoming data from the client into one + bytes object. By default this is cached but that behavior can be + changed by setting `cache` to `False`. + + Usually it's a bad idea to call this method without checking the + content length first as a client could send dozens of megabytes or more + to cause memory problems on the server. + + Note that if the form data was already parsed this method will not + return anything as form data parsing does not cache the data like + this method does. To implicitly invoke form data parsing function + set `parse_form_data` to `True`. When this is done the return value + of this method will be an empty string if the form parser handles + the data. This generally is not necessary as if the whole data is + cached (which is the default) the form parser will used the cached + data to parse the form data. Please be generally aware of checking + the content length first in any case before calling this method + to avoid exhausting server memory. + + If `as_text` is set to `True` the return value will be a decoded + string. + + .. versionadded:: 0.9 + """ + rv = getattr(self, "_cached_data", None) + if rv is None: + if parse_form_data: + self._load_form_data() + rv = self.stream.read() + if cache: + self._cached_data = rv + if as_text: + rv = rv.decode(self.charset, self.encoding_errors) + return rv # type: ignore + + @cached_property + def form(self) -> "ImmutableMultiDict[str, str]": + """The form parameters. By default an + :class:`~werkzeug.datastructures.ImmutableMultiDict` + is returned from this function. This can be changed by setting + :attr:`parameter_storage_class` to a different type. This might + be necessary if the order of the form data is important. + + Please keep in mind that file uploads will not end up here, but instead + in the :attr:`files` attribute. + + .. versionchanged:: 0.9 + + Previous to Werkzeug 0.9 this would only contain form data for POST + and PUT requests. + """ + self._load_form_data() + return self.form + + @cached_property + def values(self) -> "CombinedMultiDict[str, str]": + """A :class:`werkzeug.datastructures.CombinedMultiDict` that + combines :attr:`args` and :attr:`form`. + + For GET requests, only ``args`` are present, not ``form``. + + .. versionchanged:: 2.0 + For GET requests, only ``args`` are present, not ``form``. + """ + sources = [self.args] + + if self.method != "GET": + # GET requests can have a body, and some caching proxies + # might not treat that differently than a normal GET + # request, allowing form data to "invisibly" affect the + # cache without indication in the query string / URL. + sources.append(self.form) + + args = [] + + for d in sources: + if not isinstance(d, MultiDict): + d = MultiDict(d) + + args.append(d) + + return CombinedMultiDict(args) + + @cached_property + def files(self) -> "ImmutableMultiDict[str, FileStorage]": + """:class:`~werkzeug.datastructures.MultiDict` object containing + all uploaded files. Each key in :attr:`files` is the name from the + ````. Each value in :attr:`files` is a + Werkzeug :class:`~werkzeug.datastructures.FileStorage` object. + + It basically behaves like a standard file object you know from Python, + with the difference that it also has a + :meth:`~werkzeug.datastructures.FileStorage.save` function that can + store the file on the filesystem. + + Note that :attr:`files` will only contain data if the request method was + POST, PUT or PATCH and the ``

    `` that posted to the request had + ``enctype="multipart/form-data"``. It will be empty otherwise. + + See the :class:`~werkzeug.datastructures.MultiDict` / + :class:`~werkzeug.datastructures.FileStorage` documentation for + more details about the used data structure. + """ + self._load_form_data() + return self.files + + @property + def script_root(self) -> str: + """Alias for :attr:`self.root_path`. ``environ["SCRIPT_ROOT"]`` + without a trailing slash. + """ + return self.root_path + + @cached_property + def url_root(self) -> str: + """Alias for :attr:`root_url`. The URL with scheme, host, and + root path. For example, ``https://example.com/app/``. + """ + return self.root_url + + remote_user = environ_property[str]( + "REMOTE_USER", + doc="""If the server supports user authentication, and the + script is protected, this attribute contains the username the + user has authenticated as.""", + ) + is_multithread = environ_property[bool]( + "wsgi.multithread", + doc="""boolean that is `True` if the application is served by a + multithreaded WSGI server.""", + ) + is_multiprocess = environ_property[bool]( + "wsgi.multiprocess", + doc="""boolean that is `True` if the application is served by a + WSGI server that spawns multiple processes.""", + ) + is_run_once = environ_property[bool]( + "wsgi.run_once", + doc="""boolean that is `True` if the application will be + executed only once in a process lifetime. This is the case for + CGI for example, but it's not guaranteed that the execution only + happens one time.""", + ) + + # JSON + + #: A module or other object that has ``dumps`` and ``loads`` + #: functions that match the API of the built-in :mod:`json` module. + json_module = json + + @property + def json(self) -> t.Optional[t.Any]: + """The parsed JSON data if :attr:`mimetype` indicates JSON + (:mimetype:`application/json`, see :attr:`is_json`). + + Calls :meth:`get_json` with default arguments. + """ + return self.get_json() + + # Cached values for ``(silent=False, silent=True)``. Initialized + # with sentinel values. + _cached_json: t.Tuple[t.Any, t.Any] = (Ellipsis, Ellipsis) + + def get_json( + self, force: bool = False, silent: bool = False, cache: bool = True + ) -> t.Optional[t.Any]: + """Parse :attr:`data` as JSON. + + If the mimetype does not indicate JSON + (:mimetype:`application/json`, see :attr:`is_json`), this + returns ``None``. + + If parsing fails, :meth:`on_json_loading_failed` is called and + its return value is used as the return value. + + :param force: Ignore the mimetype and always try to parse JSON. + :param silent: Silence parsing errors and return ``None`` + instead. + :param cache: Store the parsed JSON to return for subsequent + calls. + """ + if cache and self._cached_json[silent] is not Ellipsis: + return self._cached_json[silent] + + if not (force or self.is_json): + return None + + data = self.get_data(cache=cache) + + try: + rv = self.json_module.loads(data) + except ValueError as e: + if silent: + rv = None + + if cache: + normal_rv, _ = self._cached_json + self._cached_json = (normal_rv, rv) + else: + rv = self.on_json_loading_failed(e) + + if cache: + _, silent_rv = self._cached_json + self._cached_json = (rv, silent_rv) + else: + if cache: + self._cached_json = (rv, rv) + + return rv + + def on_json_loading_failed(self, e: ValueError) -> t.Any: + """Called if :meth:`get_json` parsing fails and isn't silenced. + If this method returns a value, it is used as the return value + for :meth:`get_json`. The default implementation raises + :exc:`~werkzeug.exceptions.BadRequest`. + """ + raise BadRequest(f"Failed to decode JSON object: {e}") + + +class StreamOnlyMixin: + """Mixin to create a ``Request`` that disables the ``data``, + ``form``, and ``files`` properties. Only ``stream`` is available. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Create the request with + ``shallow=True`` instead. + + .. versionadded:: 0.9 + """ + + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'StreamOnlyMixin' is deprecated and will be removed in" + " Werkzeug 2.1. Create the request with 'shallow=True'" + " instead.", + DeprecationWarning, + stacklevel=2, + ) + kwargs["shallow"] = True + super().__init__(*args, **kwargs) # type: ignore + + +class PlainRequest(StreamOnlyMixin, Request): + """A request object without ``data``, ``form``, and ``files``. + + .. deprecated:: 2.0 + Will be removed in Werkzeug 2.1. Create the request with + ``shallow=True`` instead. + + .. versionadded:: 0.9 + """ + + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'PlainRequest' is deprecated and will be removed in" + " Werkzeug 2.1. Create the request with 'shallow=True'" + " instead.", + DeprecationWarning, + stacklevel=2, + ) + + # Don't show the DeprecationWarning for StreamOnlyMixin. + with warnings.catch_warnings(): + warnings.simplefilter("ignore", DeprecationWarning) + super().__init__(*args, **kwargs) diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/response.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/response.py new file mode 100644 index 00000000..d365c4e0 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/response.py @@ -0,0 +1,890 @@ +import json +import typing +import typing as t +import warnings +from http import HTTPStatus + +from .._internal import _to_bytes +from ..datastructures import Headers +from ..http import remove_entity_headers +from ..sansio.response import Response as _SansIOResponse +from ..urls import iri_to_uri +from ..urls import url_join +from ..utils import cached_property +from ..wsgi import ClosingIterator +from ..wsgi import get_current_url +from werkzeug._internal import _get_environ +from werkzeug.http import generate_etag +from werkzeug.http import http_date +from werkzeug.http import is_resource_modified +from werkzeug.http import parse_etags +from werkzeug.http import parse_range_header +from werkzeug.wsgi import _RangeWrapper + +if t.TYPE_CHECKING: + import typing_extensions as te + from _typeshed.wsgi import StartResponse + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +def _warn_if_string(iterable: t.Iterable) -> None: + """Helper for the response objects to check if the iterable returned + to the WSGI server is not a string. + """ + if isinstance(iterable, str): + warnings.warn( + "Response iterable was set to a string. This will appear to" + " work but means that the server will send the data to the" + " client one character at a time. This is almost never" + " intended behavior, use 'response.data' to assign strings" + " to the response object.", + stacklevel=2, + ) + + +def _iter_encoded( + iterable: t.Iterable[t.Union[str, bytes]], charset: str +) -> t.Iterator[bytes]: + for item in iterable: + if isinstance(item, str): + yield item.encode(charset) + else: + yield item + + +def _clean_accept_ranges(accept_ranges: t.Union[bool, str]) -> str: + if accept_ranges is True: + return "bytes" + elif accept_ranges is False: + return "none" + elif isinstance(accept_ranges, str): + return accept_ranges + raise ValueError("Invalid accept_ranges value") + + +class Response(_SansIOResponse): + """Represents an outgoing WSGI HTTP response with body, status, and + headers. Has properties and methods for using the functionality + defined by various HTTP specs. + + The response body is flexible to support different use cases. The + simple form is passing bytes, or a string which will be encoded as + UTF-8. Passing an iterable of bytes or strings makes this a + streaming response. A generator is particularly useful for building + a CSV file in memory or using SSE (Server Sent Events). A file-like + object is also iterable, although the + :func:`~werkzeug.utils.send_file` helper should be used in that + case. + + The response object is itself a WSGI application callable. When + called (:meth:`__call__`) with ``environ`` and ``start_response``, + it will pass its status and headers to ``start_response`` then + return its body as an iterable. + + .. code-block:: python + + from werkzeug.wrappers.response import Response + + def index(): + return Response("Hello, World!") + + def application(environ, start_response): + path = environ.get("PATH_INFO") or "/" + + if path == "/": + response = index() + else: + response = Response("Not Found", status=404) + + return response(environ, start_response) + + :param response: The data for the body of the response. A string or + bytes, or tuple or list of strings or bytes, for a fixed-length + response, or any other iterable of strings or bytes for a + streaming response. Defaults to an empty body. + :param status: The status code for the response. Either an int, in + which case the default status message is added, or a string in + the form ``{code} {message}``, like ``404 Not Found``. Defaults + to 200. + :param headers: A :class:`~werkzeug.datastructures.Headers` object, + or a list of ``(key, value)`` tuples that will be converted to a + ``Headers`` object. + :param mimetype: The mime type (content type without charset or + other parameters) of the response. If the value starts with + ``text/`` (or matches some other special cases), the charset + will be added to create the ``content_type``. + :param content_type: The full content type of the response. + Overrides building the value from ``mimetype``. + :param direct_passthrough: Pass the response body directly through + as the WSGI iterable. This can be used when the body is a binary + file or other iterator of bytes, to skip some unnecessary + checks. Use :func:`~werkzeug.utils.send_file` instead of setting + this manually. + + .. versionchanged:: 2.0 + Combine ``BaseResponse`` and mixins into a single ``Response`` + class. Using the old classes is deprecated and will be removed + in Werkzeug 2.1. + + .. versionchanged:: 0.5 + The ``direct_passthrough`` parameter was added. + """ + + #: if set to `False` accessing properties on the response object will + #: not try to consume the response iterator and convert it into a list. + #: + #: .. versionadded:: 0.6.2 + #: + #: That attribute was previously called `implicit_seqence_conversion`. + #: (Notice the typo). If you did use this feature, you have to adapt + #: your code to the name change. + implicit_sequence_conversion = True + + #: Should this response object correct the location header to be RFC + #: conformant? This is true by default. + #: + #: .. versionadded:: 0.8 + autocorrect_location_header = True + + #: Should this response object automatically set the content-length + #: header if possible? This is true by default. + #: + #: .. versionadded:: 0.8 + automatically_set_content_length = True + + #: The response body to send as the WSGI iterable. A list of strings + #: or bytes represents a fixed-length response, any other iterable + #: is a streaming response. Strings are encoded to bytes as UTF-8. + #: + #: Do not set to a plain string or bytes, that will cause sending + #: the response to be very inefficient as it will iterate one byte + #: at a time. + response: t.Union[t.Iterable[str], t.Iterable[bytes]] + + def __init__( + self, + response: t.Optional[ + t.Union[t.Iterable[bytes], bytes, t.Iterable[str], str] + ] = None, + status: t.Optional[t.Union[int, str, HTTPStatus]] = None, + headers: t.Optional[ + t.Union[ + t.Mapping[str, t.Union[str, int, t.Iterable[t.Union[str, int]]]], + t.Iterable[t.Tuple[str, t.Union[str, int]]], + ] + ] = None, + mimetype: t.Optional[str] = None, + content_type: t.Optional[str] = None, + direct_passthrough: bool = False, + ) -> None: + super().__init__( + status=status, + headers=headers, + mimetype=mimetype, + content_type=content_type, + ) + + #: Pass the response body directly through as the WSGI iterable. + #: This can be used when the body is a binary file or other + #: iterator of bytes, to skip some unnecessary checks. Use + #: :func:`~werkzeug.utils.send_file` instead of setting this + #: manually. + self.direct_passthrough = direct_passthrough + self._on_close: t.List[t.Callable[[], t.Any]] = [] + + # we set the response after the headers so that if a class changes + # the charset attribute, the data is set in the correct charset. + if response is None: + self.response = [] + elif isinstance(response, (str, bytes, bytearray)): + self.set_data(response) + else: + self.response = response + + def call_on_close(self, func: t.Callable[[], t.Any]) -> t.Callable[[], t.Any]: + """Adds a function to the internal list of functions that should + be called as part of closing down the response. Since 0.7 this + function also returns the function that was passed so that this + can be used as a decorator. + + .. versionadded:: 0.6 + """ + self._on_close.append(func) + return func + + def __repr__(self) -> str: + if self.is_sequence: + body_info = f"{sum(map(len, self.iter_encoded()))} bytes" + else: + body_info = "streamed" if self.is_streamed else "likely-streamed" + return f"<{type(self).__name__} {body_info} [{self.status}]>" + + @classmethod + def force_type( + cls, response: "Response", environ: t.Optional["WSGIEnvironment"] = None + ) -> "Response": + """Enforce that the WSGI response is a response object of the current + type. Werkzeug will use the :class:`Response` internally in many + situations like the exceptions. If you call :meth:`get_response` on an + exception you will get back a regular :class:`Response` object, even + if you are using a custom subclass. + + This method can enforce a given response type, and it will also + convert arbitrary WSGI callables into response objects if an environ + is provided:: + + # convert a Werkzeug response object into an instance of the + # MyResponseClass subclass. + response = MyResponseClass.force_type(response) + + # convert any WSGI application into a response object + response = MyResponseClass.force_type(response, environ) + + This is especially useful if you want to post-process responses in + the main dispatcher and use functionality provided by your subclass. + + Keep in mind that this will modify response objects in place if + possible! + + :param response: a response object or wsgi application. + :param environ: a WSGI environment object. + :return: a response object. + """ + if not isinstance(response, Response): + if environ is None: + raise TypeError( + "cannot convert WSGI application into response" + " objects without an environ" + ) + + from ..test import run_wsgi_app + + response = Response(*run_wsgi_app(response, environ)) + + response.__class__ = cls + return response + + @classmethod + def from_app( + cls, app: "WSGIApplication", environ: "WSGIEnvironment", buffered: bool = False + ) -> "Response": + """Create a new response object from an application output. This + works best if you pass it an application that returns a generator all + the time. Sometimes applications may use the `write()` callable + returned by the `start_response` function. This tries to resolve such + edge cases automatically. But if you don't get the expected output + you should set `buffered` to `True` which enforces buffering. + + :param app: the WSGI application to execute. + :param environ: the WSGI environment to execute against. + :param buffered: set to `True` to enforce buffering. + :return: a response object. + """ + from ..test import run_wsgi_app + + return cls(*run_wsgi_app(app, environ, buffered)) + + @typing.overload + def get_data(self, as_text: "te.Literal[False]" = False) -> bytes: + ... + + @typing.overload + def get_data(self, as_text: "te.Literal[True]") -> str: + ... + + def get_data(self, as_text: bool = False) -> t.Union[bytes, str]: + """The string representation of the response body. Whenever you call + this property the response iterable is encoded and flattened. This + can lead to unwanted behavior if you stream big data. + + This behavior can be disabled by setting + :attr:`implicit_sequence_conversion` to `False`. + + If `as_text` is set to `True` the return value will be a decoded + string. + + .. versionadded:: 0.9 + """ + self._ensure_sequence() + rv = b"".join(self.iter_encoded()) + + if as_text: + return rv.decode(self.charset) + + return rv + + def set_data(self, value: t.Union[bytes, str]) -> None: + """Sets a new string as response. The value must be a string or + bytes. If a string is set it's encoded to the charset of the + response (utf-8 by default). + + .. versionadded:: 0.9 + """ + # if a string is set, it's encoded directly so that we + # can set the content length + if isinstance(value, str): + value = value.encode(self.charset) + else: + value = bytes(value) + self.response = [value] + if self.automatically_set_content_length: + self.headers["Content-Length"] = str(len(value)) + + data = property( + get_data, + set_data, + doc="A descriptor that calls :meth:`get_data` and :meth:`set_data`.", + ) + + def calculate_content_length(self) -> t.Optional[int]: + """Returns the content length if available or `None` otherwise.""" + try: + self._ensure_sequence() + except RuntimeError: + return None + return sum(len(x) for x in self.iter_encoded()) + + def _ensure_sequence(self, mutable: bool = False) -> None: + """This method can be called by methods that need a sequence. If + `mutable` is true, it will also ensure that the response sequence + is a standard Python list. + + .. versionadded:: 0.6 + """ + if self.is_sequence: + # if we need a mutable object, we ensure it's a list. + if mutable and not isinstance(self.response, list): + self.response = list(self.response) # type: ignore + return + if self.direct_passthrough: + raise RuntimeError( + "Attempted implicit sequence conversion but the" + " response object is in direct passthrough mode." + ) + if not self.implicit_sequence_conversion: + raise RuntimeError( + "The response object required the iterable to be a" + " sequence, but the implicit conversion was disabled." + " Call make_sequence() yourself." + ) + self.make_sequence() + + def make_sequence(self) -> None: + """Converts the response iterator in a list. By default this happens + automatically if required. If `implicit_sequence_conversion` is + disabled, this method is not automatically called and some properties + might raise exceptions. This also encodes all the items. + + .. versionadded:: 0.6 + """ + if not self.is_sequence: + # if we consume an iterable we have to ensure that the close + # method of the iterable is called if available when we tear + # down the response + close = getattr(self.response, "close", None) + self.response = list(self.iter_encoded()) + if close is not None: + self.call_on_close(close) + + def iter_encoded(self) -> t.Iterator[bytes]: + """Iter the response encoded with the encoding of the response. + If the response object is invoked as WSGI application the return + value of this method is used as application iterator unless + :attr:`direct_passthrough` was activated. + """ + if __debug__: + _warn_if_string(self.response) + # Encode in a separate function so that self.response is fetched + # early. This allows us to wrap the response with the return + # value from get_app_iter or iter_encoded. + return _iter_encoded(self.response, self.charset) + + @property + def is_streamed(self) -> bool: + """If the response is streamed (the response is not an iterable with + a length information) this property is `True`. In this case streamed + means that there is no information about the number of iterations. + This is usually `True` if a generator is passed to the response object. + + This is useful for checking before applying some sort of post + filtering that should not take place for streamed responses. + """ + try: + len(self.response) # type: ignore + except (TypeError, AttributeError): + return True + return False + + @property + def is_sequence(self) -> bool: + """If the iterator is buffered, this property will be `True`. A + response object will consider an iterator to be buffered if the + response attribute is a list or tuple. + + .. versionadded:: 0.6 + """ + return isinstance(self.response, (tuple, list)) + + def close(self) -> None: + """Close the wrapped response if possible. You can also use the object + in a with statement which will automatically close it. + + .. versionadded:: 0.9 + Can now be used in a with statement. + """ + if hasattr(self.response, "close"): + self.response.close() # type: ignore + for func in self._on_close: + func() + + def __enter__(self) -> "Response": + return self + + def __exit__(self, exc_type, exc_value, tb): # type: ignore + self.close() + + def freeze(self, no_etag: None = None) -> None: + """Make the response object ready to be pickled. Does the + following: + + * Buffer the response into a list, ignoring + :attr:`implicity_sequence_conversion` and + :attr:`direct_passthrough`. + * Set the ``Content-Length`` header. + * Generate an ``ETag`` header if one is not already set. + + .. versionchanged:: 2.0 + An ``ETag`` header is added, the ``no_etag`` parameter is + deprecated and will be removed in Werkzeug 2.1. + + .. versionchanged:: 0.6 + The ``Content-Length`` header is set. + """ + # Always freeze the encoded response body, ignore + # implicit_sequence_conversion and direct_passthrough. + self.response = list(self.iter_encoded()) + self.headers["Content-Length"] = str(sum(map(len, self.response))) + + if no_etag is not None: + warnings.warn( + "The 'no_etag' parameter is deprecated and will be" + " removed in Werkzeug 2.1.", + DeprecationWarning, + stacklevel=2, + ) + + self.add_etag() + + def get_wsgi_headers(self, environ: "WSGIEnvironment") -> Headers: + """This is automatically called right before the response is started + and returns headers modified for the given environment. It returns a + copy of the headers from the response with some modifications applied + if necessary. + + For example the location header (if present) is joined with the root + URL of the environment. Also the content length is automatically set + to zero here for certain status codes. + + .. versionchanged:: 0.6 + Previously that function was called `fix_headers` and modified + the response object in place. Also since 0.6, IRIs in location + and content-location headers are handled properly. + + Also starting with 0.6, Werkzeug will attempt to set the content + length if it is able to figure it out on its own. This is the + case if all the strings in the response iterable are already + encoded and the iterable is buffered. + + :param environ: the WSGI environment of the request. + :return: returns a new :class:`~werkzeug.datastructures.Headers` + object. + """ + headers = Headers(self.headers) + location: t.Optional[str] = None + content_location: t.Optional[str] = None + content_length: t.Optional[t.Union[str, int]] = None + status = self.status_code + + # iterate over the headers to find all values in one go. Because + # get_wsgi_headers is used each response that gives us a tiny + # speedup. + for key, value in headers: + ikey = key.lower() + if ikey == "location": + location = value + elif ikey == "content-location": + content_location = value + elif ikey == "content-length": + content_length = value + + # make sure the location header is an absolute URL + if location is not None: + old_location = location + if isinstance(location, str): + # Safe conversion is necessary here as we might redirect + # to a broken URI scheme (for instance itms-services). + location = iri_to_uri(location, safe_conversion=True) + + if self.autocorrect_location_header: + current_url = get_current_url(environ, strip_querystring=True) + if isinstance(current_url, str): + current_url = iri_to_uri(current_url) + location = url_join(current_url, location) + if location != old_location: + headers["Location"] = location + + # make sure the content location is a URL + if content_location is not None and isinstance(content_location, str): + headers["Content-Location"] = iri_to_uri(content_location) + + if 100 <= status < 200 or status == 204: + # Per section 3.3.2 of RFC 7230, "a server MUST NOT send a + # Content-Length header field in any response with a status + # code of 1xx (Informational) or 204 (No Content)." + headers.remove("Content-Length") + elif status == 304: + remove_entity_headers(headers) + + # if we can determine the content length automatically, we + # should try to do that. But only if this does not involve + # flattening the iterator or encoding of strings in the + # response. We however should not do that if we have a 304 + # response. + if ( + self.automatically_set_content_length + and self.is_sequence + and content_length is None + and status not in (204, 304) + and not (100 <= status < 200) + ): + try: + content_length = sum(len(_to_bytes(x, "ascii")) for x in self.response) + except UnicodeError: + # Something other than bytes, can't safely figure out + # the length of the response. + pass + else: + headers["Content-Length"] = str(content_length) + + return headers + + def get_app_iter(self, environ: "WSGIEnvironment") -> t.Iterable[bytes]: + """Returns the application iterator for the given environ. Depending + on the request method and the current status code the return value + might be an empty response rather than the one from the response. + + If the request method is `HEAD` or the status code is in a range + where the HTTP specification requires an empty response, an empty + iterable is returned. + + .. versionadded:: 0.6 + + :param environ: the WSGI environment of the request. + :return: a response iterable. + """ + status = self.status_code + if ( + environ["REQUEST_METHOD"] == "HEAD" + or 100 <= status < 200 + or status in (204, 304) + ): + iterable: t.Iterable[bytes] = () + elif self.direct_passthrough: + if __debug__: + _warn_if_string(self.response) + return self.response # type: ignore + else: + iterable = self.iter_encoded() + return ClosingIterator(iterable, self.close) + + def get_wsgi_response( + self, environ: "WSGIEnvironment" + ) -> t.Tuple[t.Iterable[bytes], str, t.List[t.Tuple[str, str]]]: + """Returns the final WSGI response as tuple. The first item in + the tuple is the application iterator, the second the status and + the third the list of headers. The response returned is created + specially for the given environment. For example if the request + method in the WSGI environment is ``'HEAD'`` the response will + be empty and only the headers and status code will be present. + + .. versionadded:: 0.6 + + :param environ: the WSGI environment of the request. + :return: an ``(app_iter, status, headers)`` tuple. + """ + headers = self.get_wsgi_headers(environ) + app_iter = self.get_app_iter(environ) + return app_iter, self.status, headers.to_wsgi_list() + + def __call__( + self, environ: "WSGIEnvironment", start_response: "StartResponse" + ) -> t.Iterable[bytes]: + """Process this response as WSGI application. + + :param environ: the WSGI environment. + :param start_response: the response callable provided by the WSGI + server. + :return: an application iterator + """ + app_iter, status, headers = self.get_wsgi_response(environ) + start_response(status, headers) + return app_iter + + # JSON + + #: A module or other object that has ``dumps`` and ``loads`` + #: functions that match the API of the built-in :mod:`json` module. + json_module = json + + @property + def json(self) -> t.Optional[t.Any]: + """The parsed JSON data if :attr:`mimetype` indicates JSON + (:mimetype:`application/json`, see :attr:`is_json`). + + Calls :meth:`get_json` with default arguments. + """ + return self.get_json() + + def get_json(self, force: bool = False, silent: bool = False) -> t.Optional[t.Any]: + """Parse :attr:`data` as JSON. Useful during testing. + + If the mimetype does not indicate JSON + (:mimetype:`application/json`, see :attr:`is_json`), this + returns ``None``. + + Unlike :meth:`Request.get_json`, the result is not cached. + + :param force: Ignore the mimetype and always try to parse JSON. + :param silent: Silence parsing errors and return ``None`` + instead. + """ + if not (force or self.is_json): + return None + + data = self.get_data() + + try: + return self.json_module.loads(data) + except ValueError: + if not silent: + raise + + return None + + # Stream + + @cached_property + def stream(self) -> "ResponseStream": + """The response iterable as write-only stream.""" + return ResponseStream(self) + + def _wrap_range_response(self, start: int, length: int) -> None: + """Wrap existing Response in case of Range Request context.""" + if self.status_code == 206: + self.response = _RangeWrapper(self.response, start, length) # type: ignore + + def _is_range_request_processable(self, environ: "WSGIEnvironment") -> bool: + """Return ``True`` if `Range` header is present and if underlying + resource is considered unchanged when compared with `If-Range` header. + """ + return ( + "HTTP_IF_RANGE" not in environ + or not is_resource_modified( + environ, + self.headers.get("etag"), + None, + self.headers.get("last-modified"), + ignore_if_range=False, + ) + ) and "HTTP_RANGE" in environ + + def _process_range_request( + self, + environ: "WSGIEnvironment", + complete_length: t.Optional[int] = None, + accept_ranges: t.Optional[t.Union[bool, str]] = None, + ) -> bool: + """Handle Range Request related headers (RFC7233). If `Accept-Ranges` + header is valid, and Range Request is processable, we set the headers + as described by the RFC, and wrap the underlying response in a + RangeWrapper. + + Returns ``True`` if Range Request can be fulfilled, ``False`` otherwise. + + :raises: :class:`~werkzeug.exceptions.RequestedRangeNotSatisfiable` + if `Range` header could not be parsed or satisfied. + + .. versionchanged:: 2.0 + Returns ``False`` if the length is 0. + """ + from ..exceptions import RequestedRangeNotSatisfiable + + if ( + accept_ranges is None + or complete_length is None + or complete_length == 0 + or not self._is_range_request_processable(environ) + ): + return False + + parsed_range = parse_range_header(environ.get("HTTP_RANGE")) + + if parsed_range is None: + raise RequestedRangeNotSatisfiable(complete_length) + + range_tuple = parsed_range.range_for_length(complete_length) + content_range_header = parsed_range.to_content_range_header(complete_length) + + if range_tuple is None or content_range_header is None: + raise RequestedRangeNotSatisfiable(complete_length) + + content_length = range_tuple[1] - range_tuple[0] + self.headers["Content-Length"] = content_length + self.headers["Accept-Ranges"] = accept_ranges + self.content_range = content_range_header # type: ignore + self.status_code = 206 + self._wrap_range_response(range_tuple[0], content_length) + return True + + def make_conditional( + self, + request_or_environ: "WSGIEnvironment", + accept_ranges: t.Union[bool, str] = False, + complete_length: t.Optional[int] = None, + ) -> "Response": + """Make the response conditional to the request. This method works + best if an etag was defined for the response already. The `add_etag` + method can be used to do that. If called without etag just the date + header is set. + + This does nothing if the request method in the request or environ is + anything but GET or HEAD. + + For optimal performance when handling range requests, it's recommended + that your response data object implements `seekable`, `seek` and `tell` + methods as described by :py:class:`io.IOBase`. Objects returned by + :meth:`~werkzeug.wsgi.wrap_file` automatically implement those methods. + + It does not remove the body of the response because that's something + the :meth:`__call__` function does for us automatically. + + Returns self so that you can do ``return resp.make_conditional(req)`` + but modifies the object in-place. + + :param request_or_environ: a request object or WSGI environment to be + used to make the response conditional + against. + :param accept_ranges: This parameter dictates the value of + `Accept-Ranges` header. If ``False`` (default), + the header is not set. If ``True``, it will be set + to ``"bytes"``. If ``None``, it will be set to + ``"none"``. If it's a string, it will use this + value. + :param complete_length: Will be used only in valid Range Requests. + It will set `Content-Range` complete length + value and compute `Content-Length` real value. + This parameter is mandatory for successful + Range Requests completion. + :raises: :class:`~werkzeug.exceptions.RequestedRangeNotSatisfiable` + if `Range` header could not be parsed or satisfied. + + .. versionchanged:: 2.0 + Range processing is skipped if length is 0 instead of + raising a 416 Range Not Satisfiable error. + """ + environ = _get_environ(request_or_environ) + if environ["REQUEST_METHOD"] in ("GET", "HEAD"): + # if the date is not in the headers, add it now. We however + # will not override an already existing header. Unfortunately + # this header will be overriden by many WSGI servers including + # wsgiref. + if "date" not in self.headers: + self.headers["Date"] = http_date() + accept_ranges = _clean_accept_ranges(accept_ranges) + is206 = self._process_range_request(environ, complete_length, accept_ranges) + if not is206 and not is_resource_modified( + environ, + self.headers.get("etag"), + None, + self.headers.get("last-modified"), + ): + if parse_etags(environ.get("HTTP_IF_MATCH")): + self.status_code = 412 + else: + self.status_code = 304 + if ( + self.automatically_set_content_length + and "content-length" not in self.headers + ): + length = self.calculate_content_length() + if length is not None: + self.headers["Content-Length"] = length + return self + + def add_etag(self, overwrite: bool = False, weak: bool = False) -> None: + """Add an etag for the current response if there is none yet. + + .. versionchanged:: 2.0 + SHA-1 is used to generate the value. MD5 may not be + available in some environments. + """ + if overwrite or "etag" not in self.headers: + self.set_etag(generate_etag(self.get_data()), weak) + + +class ResponseStream: + """A file descriptor like object used by the :class:`ResponseStreamMixin` to + represent the body of the stream. It directly pushes into the response + iterable of the response object. + """ + + mode = "wb+" + + def __init__(self, response: Response): + self.response = response + self.closed = False + + def write(self, value: bytes) -> int: + if self.closed: + raise ValueError("I/O operation on closed file") + self.response._ensure_sequence(mutable=True) + self.response.response.append(value) # type: ignore + self.response.headers.pop("Content-Length", None) + return len(value) + + def writelines(self, seq: t.Iterable[bytes]) -> None: + for item in seq: + self.write(item) + + def close(self) -> None: + self.closed = True + + def flush(self) -> None: + if self.closed: + raise ValueError("I/O operation on closed file") + + def isatty(self) -> bool: + if self.closed: + raise ValueError("I/O operation on closed file") + return False + + def tell(self) -> int: + self.response._ensure_sequence() + return sum(map(len, self.response.response)) + + @property + def encoding(self) -> str: + return self.response.charset + + +class ResponseStreamMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'ResponseStreamMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Response' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/user_agent.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/user_agent.py new file mode 100644 index 00000000..184ffd02 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wrappers/user_agent.py @@ -0,0 +1,14 @@ +import typing as t +import warnings + + +class UserAgentMixin: + def __init__(self, *args: t.Any, **kwargs: t.Any) -> None: + warnings.warn( + "'UserAgentMixin' is deprecated and will be removed in" + " Werkzeug 2.1. 'Request' now includes the functionality" + " directly.", + DeprecationWarning, + stacklevel=2, + ) + super().__init__(*args, **kwargs) # type: ignore diff --git a/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wsgi.py b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wsgi.py new file mode 100644 index 00000000..9cfa74de --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Lib/site-packages/werkzeug/wsgi.py @@ -0,0 +1,982 @@ +import io +import re +import typing as t +from functools import partial +from functools import update_wrapper +from itertools import chain + +from ._internal import _make_encode_wrapper +from ._internal import _to_bytes +from ._internal import _to_str +from .sansio import utils as _sansio_utils +from .sansio.utils import host_is_trusted # noqa: F401 # Imported as part of API +from .urls import _URLTuple +from .urls import uri_to_iri +from .urls import url_join +from .urls import url_parse +from .urls import url_quote + +if t.TYPE_CHECKING: + from _typeshed.wsgi import WSGIApplication + from _typeshed.wsgi import WSGIEnvironment + + +def responder(f: t.Callable[..., "WSGIApplication"]) -> "WSGIApplication": + """Marks a function as responder. Decorate a function with it and it + will automatically call the return value as WSGI application. + + Example:: + + @responder + def application(environ, start_response): + return Response('Hello World!') + """ + return update_wrapper(lambda *a: f(*a)(*a[-2:]), f) + + +def get_current_url( + environ: "WSGIEnvironment", + root_only: bool = False, + strip_querystring: bool = False, + host_only: bool = False, + trusted_hosts: t.Optional[t.Iterable[str]] = None, +) -> str: + """Recreate the URL for a request from the parts in a WSGI + environment. + + The URL is an IRI, not a URI, so it may contain Unicode characters. + Use :func:`~werkzeug.urls.iri_to_uri` to convert it to ASCII. + + :param environ: The WSGI environment to get the URL parts from. + :param root_only: Only build the root path, don't include the + remaining path or query string. + :param strip_querystring: Don't include the query string. + :param host_only: Only build the scheme and host. + :param trusted_hosts: A list of trusted host names to validate the + host against. + """ + parts = { + "scheme": environ["wsgi.url_scheme"], + "host": get_host(environ, trusted_hosts), + } + + if not host_only: + parts["root_path"] = environ.get("SCRIPT_NAME", "") + + if not root_only: + parts["path"] = environ.get("PATH_INFO", "") + + if not strip_querystring: + parts["query_string"] = environ.get("QUERY_STRING", "").encode("latin1") + + return _sansio_utils.get_current_url(**parts) + + +def _get_server( + environ: "WSGIEnvironment", +) -> t.Optional[t.Tuple[str, t.Optional[int]]]: + name = environ.get("SERVER_NAME") + + if name is None: + return None + + try: + port: t.Optional[int] = int(environ.get("SERVER_PORT", None)) + except (TypeError, ValueError): + # unix socket + port = None + + return name, port + + +def get_host( + environ: "WSGIEnvironment", trusted_hosts: t.Optional[t.Iterable[str]] = None +) -> str: + """Return the host for the given WSGI environment. + + The ``Host`` header is preferred, then ``SERVER_NAME`` if it's not + set. The returned host will only contain the port if it is different + than the standard port for the protocol. + + Optionally, verify that the host is trusted using + :func:`host_is_trusted` and raise a + :exc:`~werkzeug.exceptions.SecurityError` if it is not. + + :param environ: A WSGI environment dict. + :param trusted_hosts: A list of trusted host names. + + :return: Host, with port if necessary. + :raise ~werkzeug.exceptions.SecurityError: If the host is not + trusted. + """ + return _sansio_utils.get_host( + environ["wsgi.url_scheme"], + environ.get("HTTP_HOST"), + _get_server(environ), + trusted_hosts, + ) + + +def get_content_length(environ: "WSGIEnvironment") -> t.Optional[int]: + """Returns the content length from the WSGI environment as + integer. If it's not available or chunked transfer encoding is used, + ``None`` is returned. + + .. versionadded:: 0.9 + + :param environ: the WSGI environ to fetch the content length from. + """ + if environ.get("HTTP_TRANSFER_ENCODING", "") == "chunked": + return None + + content_length = environ.get("CONTENT_LENGTH") + if content_length is not None: + try: + return max(0, int(content_length)) + except (ValueError, TypeError): + pass + return None + + +def get_input_stream( + environ: "WSGIEnvironment", safe_fallback: bool = True +) -> t.IO[bytes]: + """Returns the input stream from the WSGI environment and wraps it + in the most sensible way possible. The stream returned is not the + raw WSGI stream in most cases but one that is safe to read from + without taking into account the content length. + + If content length is not set, the stream will be empty for safety reasons. + If the WSGI server supports chunked or infinite streams, it should set + the ``wsgi.input_terminated`` value in the WSGI environ to indicate that. + + .. versionadded:: 0.9 + + :param environ: the WSGI environ to fetch the stream from. + :param safe_fallback: use an empty stream as a safe fallback when the + content length is not set. Disabling this allows infinite streams, + which can be a denial-of-service risk. + """ + stream = t.cast(t.IO[bytes], environ["wsgi.input"]) + content_length = get_content_length(environ) + + # A wsgi extension that tells us if the input is terminated. In + # that case we return the stream unchanged as we know we can safely + # read it until the end. + if environ.get("wsgi.input_terminated"): + return stream + + # If the request doesn't specify a content length, returning the stream is + # potentially dangerous because it could be infinite, malicious or not. If + # safe_fallback is true, return an empty stream instead for safety. + if content_length is None: + return io.BytesIO() if safe_fallback else stream + + # Otherwise limit the stream to the content length + return t.cast(t.IO[bytes], LimitedStream(stream, content_length)) + + +def get_query_string(environ: "WSGIEnvironment") -> str: + """Returns the ``QUERY_STRING`` from the WSGI environment. This also + takes care of the WSGI decoding dance. The string returned will be + restricted to ASCII characters. + + :param environ: WSGI environment to get the query string from. + + .. versionadded:: 0.9 + """ + qs = environ.get("QUERY_STRING", "").encode("latin1") + # QUERY_STRING really should be ascii safe but some browsers + # will send us some unicode stuff (I am looking at you IE). + # In that case we want to urllib quote it badly. + return url_quote(qs, safe=":&%=+$!*'(),") + + +def get_path_info( + environ: "WSGIEnvironment", charset: str = "utf-8", errors: str = "replace" +) -> str: + """Return the ``PATH_INFO`` from the WSGI environment and decode it + unless ``charset`` is ``None``. + + :param environ: WSGI environment to get the path from. + :param charset: The charset for the path info, or ``None`` if no + decoding should be performed. + :param errors: The decoding error handling. + + .. versionadded:: 0.9 + """ + path = environ.get("PATH_INFO", "").encode("latin1") + return _to_str(path, charset, errors, allow_none_charset=True) # type: ignore + + +def get_script_name( + environ: "WSGIEnvironment", charset: str = "utf-8", errors: str = "replace" +) -> str: + """Return the ``SCRIPT_NAME`` from the WSGI environment and decode + it unless `charset` is set to ``None``. + + :param environ: WSGI environment to get the path from. + :param charset: The charset for the path, or ``None`` if no decoding + should be performed. + :param errors: The decoding error handling. + + .. versionadded:: 0.9 + """ + path = environ.get("SCRIPT_NAME", "").encode("latin1") + return _to_str(path, charset, errors, allow_none_charset=True) # type: ignore + + +def pop_path_info( + environ: "WSGIEnvironment", charset: str = "utf-8", errors: str = "replace" +) -> t.Optional[str]: + """Removes and returns the next segment of `PATH_INFO`, pushing it onto + `SCRIPT_NAME`. Returns `None` if there is nothing left on `PATH_INFO`. + + If the `charset` is set to `None` bytes are returned. + + If there are empty segments (``'/foo//bar``) these are ignored but + properly pushed to the `SCRIPT_NAME`: + + >>> env = {'SCRIPT_NAME': '/foo', 'PATH_INFO': '/a/b'} + >>> pop_path_info(env) + 'a' + >>> env['SCRIPT_NAME'] + '/foo/a' + >>> pop_path_info(env) + 'b' + >>> env['SCRIPT_NAME'] + '/foo/a/b' + + .. versionadded:: 0.5 + + .. versionchanged:: 0.9 + The path is now decoded and a charset and encoding + parameter can be provided. + + :param environ: the WSGI environment that is modified. + :param charset: The ``encoding`` parameter passed to + :func:`bytes.decode`. + :param errors: The ``errors`` paramater passed to + :func:`bytes.decode`. + """ + path = environ.get("PATH_INFO") + if not path: + return None + + script_name = environ.get("SCRIPT_NAME", "") + + # shift multiple leading slashes over + old_path = path + path = path.lstrip("/") + if path != old_path: + script_name += "/" * (len(old_path) - len(path)) + + if "/" not in path: + environ["PATH_INFO"] = "" + environ["SCRIPT_NAME"] = script_name + path + rv = path.encode("latin1") + else: + segment, path = path.split("/", 1) + environ["PATH_INFO"] = f"/{path}" + environ["SCRIPT_NAME"] = script_name + segment + rv = segment.encode("latin1") + + return _to_str(rv, charset, errors, allow_none_charset=True) # type: ignore + + +def peek_path_info( + environ: "WSGIEnvironment", charset: str = "utf-8", errors: str = "replace" +) -> t.Optional[str]: + """Returns the next segment on the `PATH_INFO` or `None` if there + is none. Works like :func:`pop_path_info` without modifying the + environment: + + >>> env = {'SCRIPT_NAME': '/foo', 'PATH_INFO': '/a/b'} + >>> peek_path_info(env) + 'a' + >>> peek_path_info(env) + 'a' + + If the `charset` is set to `None` bytes are returned. + + .. versionadded:: 0.5 + + .. versionchanged:: 0.9 + The path is now decoded and a charset and encoding + parameter can be provided. + + :param environ: the WSGI environment that is checked. + """ + segments = environ.get("PATH_INFO", "").lstrip("/").split("/", 1) + if segments: + return _to_str( # type: ignore + segments[0].encode("latin1"), charset, errors, allow_none_charset=True + ) + return None + + +def extract_path_info( + environ_or_baseurl: t.Union[str, "WSGIEnvironment"], + path_or_url: t.Union[str, _URLTuple], + charset: str = "utf-8", + errors: str = "werkzeug.url_quote", + collapse_http_schemes: bool = True, +) -> t.Optional[str]: + """Extracts the path info from the given URL (or WSGI environment) and + path. The path info returned is a string. The URLs might also be IRIs. + + If the path info could not be determined, `None` is returned. + + Some examples: + + >>> extract_path_info('http://example.com/app', '/app/hello') + '/hello' + >>> extract_path_info('http://example.com/app', + ... 'https://example.com/app/hello') + '/hello' + >>> extract_path_info('http://example.com/app', + ... 'https://example.com/app/hello', + ... collapse_http_schemes=False) is None + True + + Instead of providing a base URL you can also pass a WSGI environment. + + :param environ_or_baseurl: a WSGI environment dict, a base URL or + base IRI. This is the root of the + application. + :param path_or_url: an absolute path from the server root, a + relative path (in which case it's the path info) + or a full URL. + :param charset: the charset for byte data in URLs + :param errors: the error handling on decode + :param collapse_http_schemes: if set to `False` the algorithm does + not assume that http and https on the + same server point to the same + resource. + + .. versionchanged:: 0.15 + The ``errors`` parameter defaults to leaving invalid bytes + quoted instead of replacing them. + + .. versionadded:: 0.6 + """ + + def _normalize_netloc(scheme: str, netloc: str) -> str: + parts = netloc.split("@", 1)[-1].split(":", 1) + port: t.Optional[str] + + if len(parts) == 2: + netloc, port = parts + if (scheme == "http" and port == "80") or ( + scheme == "https" and port == "443" + ): + port = None + else: + netloc = parts[0] + port = None + + if port is not None: + netloc += f":{port}" + + return netloc + + # make sure whatever we are working on is a IRI and parse it + path = uri_to_iri(path_or_url, charset, errors) + if isinstance(environ_or_baseurl, dict): + environ_or_baseurl = get_current_url(environ_or_baseurl, root_only=True) + base_iri = uri_to_iri(environ_or_baseurl, charset, errors) + base_scheme, base_netloc, base_path = url_parse(base_iri)[:3] + cur_scheme, cur_netloc, cur_path = url_parse(url_join(base_iri, path))[:3] + + # normalize the network location + base_netloc = _normalize_netloc(base_scheme, base_netloc) + cur_netloc = _normalize_netloc(cur_scheme, cur_netloc) + + # is that IRI even on a known HTTP scheme? + if collapse_http_schemes: + for scheme in base_scheme, cur_scheme: + if scheme not in ("http", "https"): + return None + else: + if not (base_scheme in ("http", "https") and base_scheme == cur_scheme): + return None + + # are the netlocs compatible? + if base_netloc != cur_netloc: + return None + + # are we below the application path? + base_path = base_path.rstrip("/") + if not cur_path.startswith(base_path): + return None + + return f"/{cur_path[len(base_path) :].lstrip('/')}" + + +class ClosingIterator: + """The WSGI specification requires that all middlewares and gateways + respect the `close` callback of the iterable returned by the application. + Because it is useful to add another close action to a returned iterable + and adding a custom iterable is a boring task this class can be used for + that:: + + return ClosingIterator(app(environ, start_response), [cleanup_session, + cleanup_locals]) + + If there is just one close function it can be passed instead of the list. + + A closing iterator is not needed if the application uses response objects + and finishes the processing if the response is started:: + + try: + return response(environ, start_response) + finally: + cleanup_session() + cleanup_locals() + """ + + def __init__( + self, + iterable: t.Iterable[bytes], + callbacks: t.Optional[ + t.Union[t.Callable[[], None], t.Iterable[t.Callable[[], None]]] + ] = None, + ) -> None: + iterator = iter(iterable) + self._next = t.cast(t.Callable[[], bytes], partial(next, iterator)) + if callbacks is None: + callbacks = [] + elif callable(callbacks): + callbacks = [callbacks] + else: + callbacks = list(callbacks) + iterable_close = getattr(iterable, "close", None) + if iterable_close: + callbacks.insert(0, iterable_close) + self._callbacks = callbacks + + def __iter__(self) -> "ClosingIterator": + return self + + def __next__(self) -> bytes: + return self._next() + + def close(self) -> None: + for callback in self._callbacks: + callback() + + +def wrap_file( + environ: "WSGIEnvironment", file: t.IO[bytes], buffer_size: int = 8192 +) -> t.Iterable[bytes]: + """Wraps a file. This uses the WSGI server's file wrapper if available + or otherwise the generic :class:`FileWrapper`. + + .. versionadded:: 0.5 + + If the file wrapper from the WSGI server is used it's important to not + iterate over it from inside the application but to pass it through + unchanged. If you want to pass out a file wrapper inside a response + object you have to set :attr:`Response.direct_passthrough` to `True`. + + More information about file wrappers are available in :pep:`333`. + + :param file: a :class:`file`-like object with a :meth:`~file.read` method. + :param buffer_size: number of bytes for one iteration. + """ + return environ.get("wsgi.file_wrapper", FileWrapper)( # type: ignore + file, buffer_size + ) + + +class FileWrapper: + """This class can be used to convert a :class:`file`-like object into + an iterable. It yields `buffer_size` blocks until the file is fully + read. + + You should not use this class directly but rather use the + :func:`wrap_file` function that uses the WSGI server's file wrapper + support if it's available. + + .. versionadded:: 0.5 + + If you're using this object together with a :class:`Response` you have + to use the `direct_passthrough` mode. + + :param file: a :class:`file`-like object with a :meth:`~file.read` method. + :param buffer_size: number of bytes for one iteration. + """ + + def __init__(self, file: t.IO[bytes], buffer_size: int = 8192) -> None: + self.file = file + self.buffer_size = buffer_size + + def close(self) -> None: + if hasattr(self.file, "close"): + self.file.close() + + def seekable(self) -> bool: + if hasattr(self.file, "seekable"): + return self.file.seekable() + if hasattr(self.file, "seek"): + return True + return False + + def seek(self, *args: t.Any) -> None: + if hasattr(self.file, "seek"): + self.file.seek(*args) + + def tell(self) -> t.Optional[int]: + if hasattr(self.file, "tell"): + return self.file.tell() + return None + + def __iter__(self) -> "FileWrapper": + return self + + def __next__(self) -> bytes: + data = self.file.read(self.buffer_size) + if data: + return data + raise StopIteration() + + +class _RangeWrapper: + # private for now, but should we make it public in the future ? + + """This class can be used to convert an iterable object into + an iterable that will only yield a piece of the underlying content. + It yields blocks until the underlying stream range is fully read. + The yielded blocks will have a size that can't exceed the original + iterator defined block size, but that can be smaller. + + If you're using this object together with a :class:`Response` you have + to use the `direct_passthrough` mode. + + :param iterable: an iterable object with a :meth:`__next__` method. + :param start_byte: byte from which read will start. + :param byte_range: how many bytes to read. + """ + + def __init__( + self, + iterable: t.Union[t.Iterable[bytes], t.IO[bytes]], + start_byte: int = 0, + byte_range: t.Optional[int] = None, + ): + self.iterable = iter(iterable) + self.byte_range = byte_range + self.start_byte = start_byte + self.end_byte = None + + if byte_range is not None: + self.end_byte = start_byte + byte_range + + self.read_length = 0 + self.seekable = ( + hasattr(iterable, "seekable") and iterable.seekable() # type: ignore + ) + self.end_reached = False + + def __iter__(self) -> "_RangeWrapper": + return self + + def _next_chunk(self) -> bytes: + try: + chunk = next(self.iterable) + self.read_length += len(chunk) + return chunk + except StopIteration: + self.end_reached = True + raise + + def _first_iteration(self) -> t.Tuple[t.Optional[bytes], int]: + chunk = None + if self.seekable: + self.iterable.seek(self.start_byte) # type: ignore + self.read_length = self.iterable.tell() # type: ignore + contextual_read_length = self.read_length + else: + while self.read_length <= self.start_byte: + chunk = self._next_chunk() + if chunk is not None: + chunk = chunk[self.start_byte - self.read_length :] + contextual_read_length = self.start_byte + return chunk, contextual_read_length + + def _next(self) -> bytes: + if self.end_reached: + raise StopIteration() + chunk = None + contextual_read_length = self.read_length + if self.read_length == 0: + chunk, contextual_read_length = self._first_iteration() + if chunk is None: + chunk = self._next_chunk() + if self.end_byte is not None and self.read_length >= self.end_byte: + self.end_reached = True + return chunk[: self.end_byte - contextual_read_length] + return chunk + + def __next__(self) -> bytes: + chunk = self._next() + if chunk: + return chunk + self.end_reached = True + raise StopIteration() + + def close(self) -> None: + if hasattr(self.iterable, "close"): + self.iterable.close() # type: ignore + + +def _make_chunk_iter( + stream: t.Union[t.Iterable[bytes], t.IO[bytes]], + limit: t.Optional[int], + buffer_size: int, +) -> t.Iterator[bytes]: + """Helper for the line and chunk iter functions.""" + if isinstance(stream, (bytes, bytearray, str)): + raise TypeError( + "Passed a string or byte object instead of true iterator or stream." + ) + if not hasattr(stream, "read"): + for item in stream: + if item: + yield item + return + stream = t.cast(t.IO[bytes], stream) + if not isinstance(stream, LimitedStream) and limit is not None: + stream = t.cast(t.IO[bytes], LimitedStream(stream, limit)) + _read = stream.read + while True: + item = _read(buffer_size) + if not item: + break + yield item + + +def make_line_iter( + stream: t.Union[t.Iterable[bytes], t.IO[bytes]], + limit: t.Optional[int] = None, + buffer_size: int = 10 * 1024, + cap_at_buffer: bool = False, +) -> t.Iterator[bytes]: + """Safely iterates line-based over an input stream. If the input stream + is not a :class:`LimitedStream` the `limit` parameter is mandatory. + + This uses the stream's :meth:`~file.read` method internally as opposite + to the :meth:`~file.readline` method that is unsafe and can only be used + in violation of the WSGI specification. The same problem applies to the + `__iter__` function of the input stream which calls :meth:`~file.readline` + without arguments. + + If you need line-by-line processing it's strongly recommended to iterate + over the input stream using this helper function. + + .. versionchanged:: 0.8 + This function now ensures that the limit was reached. + + .. versionadded:: 0.9 + added support for iterators as input stream. + + .. versionadded:: 0.11.10 + added support for the `cap_at_buffer` parameter. + + :param stream: the stream or iterate to iterate over. + :param limit: the limit in bytes for the stream. (Usually + content length. Not necessary if the `stream` + is a :class:`LimitedStream`. + :param buffer_size: The optional buffer size. + :param cap_at_buffer: if this is set chunks are split if they are longer + than the buffer size. Internally this is implemented + that the buffer size might be exhausted by a factor + of two however. + """ + _iter = _make_chunk_iter(stream, limit, buffer_size) + + first_item = next(_iter, "") + if not first_item: + return + + s = _make_encode_wrapper(first_item) + empty = t.cast(bytes, s("")) + cr = t.cast(bytes, s("\r")) + lf = t.cast(bytes, s("\n")) + crlf = t.cast(bytes, s("\r\n")) + + _iter = t.cast(t.Iterator[bytes], chain((first_item,), _iter)) + + def _iter_basic_lines() -> t.Iterator[bytes]: + _join = empty.join + buffer: t.List[bytes] = [] + while True: + new_data = next(_iter, "") + if not new_data: + break + new_buf: t.List[bytes] = [] + buf_size = 0 + for item in t.cast( + t.Iterator[bytes], chain(buffer, new_data.splitlines(True)) + ): + new_buf.append(item) + buf_size += len(item) + if item and item[-1:] in crlf: + yield _join(new_buf) + new_buf = [] + elif cap_at_buffer and buf_size >= buffer_size: + rv = _join(new_buf) + while len(rv) >= buffer_size: + yield rv[:buffer_size] + rv = rv[buffer_size:] + new_buf = [rv] + buffer = new_buf + if buffer: + yield _join(buffer) + + # This hackery is necessary to merge 'foo\r' and '\n' into one item + # of 'foo\r\n' if we were unlucky and we hit a chunk boundary. + previous = empty + for item in _iter_basic_lines(): + if item == lf and previous[-1:] == cr: + previous += item + item = empty + if previous: + yield previous + previous = item + if previous: + yield previous + + +def make_chunk_iter( + stream: t.Union[t.Iterable[bytes], t.IO[bytes]], + separator: bytes, + limit: t.Optional[int] = None, + buffer_size: int = 10 * 1024, + cap_at_buffer: bool = False, +) -> t.Iterator[bytes]: + """Works like :func:`make_line_iter` but accepts a separator + which divides chunks. If you want newline based processing + you should use :func:`make_line_iter` instead as it + supports arbitrary newline markers. + + .. versionadded:: 0.8 + + .. versionadded:: 0.9 + added support for iterators as input stream. + + .. versionadded:: 0.11.10 + added support for the `cap_at_buffer` parameter. + + :param stream: the stream or iterate to iterate over. + :param separator: the separator that divides chunks. + :param limit: the limit in bytes for the stream. (Usually + content length. Not necessary if the `stream` + is otherwise already limited). + :param buffer_size: The optional buffer size. + :param cap_at_buffer: if this is set chunks are split if they are longer + than the buffer size. Internally this is implemented + that the buffer size might be exhausted by a factor + of two however. + """ + _iter = _make_chunk_iter(stream, limit, buffer_size) + + first_item = next(_iter, b"") + if not first_item: + return + + _iter = t.cast(t.Iterator[bytes], chain((first_item,), _iter)) + if isinstance(first_item, str): + separator = _to_str(separator) + _split = re.compile(f"({re.escape(separator)})").split + _join = "".join + else: + separator = _to_bytes(separator) + _split = re.compile(b"(" + re.escape(separator) + b")").split + _join = b"".join + + buffer: t.List[bytes] = [] + while True: + new_data = next(_iter, b"") + if not new_data: + break + chunks = _split(new_data) + new_buf: t.List[bytes] = [] + buf_size = 0 + for item in chain(buffer, chunks): + if item == separator: + yield _join(new_buf) + new_buf = [] + buf_size = 0 + else: + buf_size += len(item) + new_buf.append(item) + + if cap_at_buffer and buf_size >= buffer_size: + rv = _join(new_buf) + while len(rv) >= buffer_size: + yield rv[:buffer_size] + rv = rv[buffer_size:] + new_buf = [rv] + buf_size = len(rv) + + buffer = new_buf + if buffer: + yield _join(buffer) + + +class LimitedStream(io.IOBase): + """Wraps a stream so that it doesn't read more than n bytes. If the + stream is exhausted and the caller tries to get more bytes from it + :func:`on_exhausted` is called which by default returns an empty + string. The return value of that function is forwarded + to the reader function. So if it returns an empty string + :meth:`read` will return an empty string as well. + + The limit however must never be higher than what the stream can + output. Otherwise :meth:`readlines` will try to read past the + limit. + + .. admonition:: Note on WSGI compliance + + calls to :meth:`readline` and :meth:`readlines` are not + WSGI compliant because it passes a size argument to the + readline methods. Unfortunately the WSGI PEP is not safely + implementable without a size argument to :meth:`readline` + because there is no EOF marker in the stream. As a result + of that the use of :meth:`readline` is discouraged. + + For the same reason iterating over the :class:`LimitedStream` + is not portable. It internally calls :meth:`readline`. + + We strongly suggest using :meth:`read` only or using the + :func:`make_line_iter` which safely iterates line-based + over a WSGI input stream. + + :param stream: the stream to wrap. + :param limit: the limit for the stream, must not be longer than + what the string can provide if the stream does not + end with `EOF` (like `wsgi.input`) + """ + + def __init__(self, stream: t.IO[bytes], limit: int) -> None: + self._read = stream.read + self._readline = stream.readline + self._pos = 0 + self.limit = limit + + def __iter__(self) -> "LimitedStream": + return self + + @property + def is_exhausted(self) -> bool: + """If the stream is exhausted this attribute is `True`.""" + return self._pos >= self.limit + + def on_exhausted(self) -> bytes: + """This is called when the stream tries to read past the limit. + The return value of this function is returned from the reading + function. + """ + # Read null bytes from the stream so that we get the + # correct end of stream marker. + return self._read(0) + + def on_disconnect(self) -> bytes: + """What should happen if a disconnect is detected? The return + value of this function is returned from read functions in case + the client went away. By default a + :exc:`~werkzeug.exceptions.ClientDisconnected` exception is raised. + """ + from .exceptions import ClientDisconnected + + raise ClientDisconnected() + + def exhaust(self, chunk_size: int = 1024 * 64) -> None: + """Exhaust the stream. This consumes all the data left until the + limit is reached. + + :param chunk_size: the size for a chunk. It will read the chunk + until the stream is exhausted and throw away + the results. + """ + to_read = self.limit - self._pos + chunk = chunk_size + while to_read > 0: + chunk = min(to_read, chunk) + self.read(chunk) + to_read -= chunk + + def read(self, size: t.Optional[int] = None) -> bytes: + """Read `size` bytes or if size is not provided everything is read. + + :param size: the number of bytes read. + """ + if self._pos >= self.limit: + return self.on_exhausted() + if size is None or size == -1: # -1 is for consistence with file + size = self.limit + to_read = min(self.limit - self._pos, size) + try: + read = self._read(to_read) + except (OSError, ValueError): + return self.on_disconnect() + if to_read and len(read) != to_read: + return self.on_disconnect() + self._pos += len(read) + return read + + def readline(self, size: t.Optional[int] = None) -> bytes: + """Reads one line from the stream.""" + if self._pos >= self.limit: + return self.on_exhausted() + if size is None: + size = self.limit - self._pos + else: + size = min(size, self.limit - self._pos) + try: + line = self._readline(size) + except (ValueError, OSError): + return self.on_disconnect() + if size and not line: + return self.on_disconnect() + self._pos += len(line) + return line + + def readlines(self, size: t.Optional[int] = None) -> t.List[bytes]: + """Reads a file into a list of strings. It calls :meth:`readline` + until the file is read to the end. It does support the optional + `size` argument if the underlying stream supports it for + `readline`. + """ + last_pos = self._pos + result = [] + if size is not None: + end = min(self.limit, last_pos + size) + else: + end = self.limit + while True: + if size is not None: + size -= last_pos - self._pos + if self._pos >= end: + break + result.append(self.readline(size)) + if size is not None: + last_pos = self._pos + return result + + def tell(self) -> int: + """Returns the position of the stream. + + .. versionadded:: 0.9 + """ + return self._pos + + def __next__(self) -> bytes: + line = self.readline() + if not line: + raise StopIteration() + return line + + def readable(self) -> bool: + return True diff --git a/Rahul/task4/pyvenv3.9/Scripts/Activate.ps1 b/Rahul/task4/pyvenv3.9/Scripts/Activate.ps1 new file mode 100644 index 00000000..e06da144 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Scripts/Activate.ps1 @@ -0,0 +1,399 @@ +<# +.Synopsis +Activate a Python virtual environment for the current PowerShell session. + +.Description +Pushes the python executable for a virtual environment to the front of the +$Env:PATH environment variable and sets the prompt to signify that you are +in a Python virtual environment. Makes use of the command line switches as +well as the `pyvenv.cfg` file values present in the virtual environment. + +.Parameter VenvDir +Path to the directory that contains the virtual environment to activate. The +default value for this is the parent of the directory that the Activate.ps1 +script is located within. + +.Parameter Prompt +The prompt prefix to display when this virtual environment is activated. By +default, this prompt is the name of the virtual environment folder (VenvDir) +surrounded by parentheses and followed by a single space (ie. '(.venv) '). + +.Example +Activate.ps1 +Activates the Python virtual environment that contains the Activate.ps1 script. + +.Example +Activate.ps1 -Verbose +Activates the Python virtual environment that contains the Activate.ps1 script, +and shows extra information about the activation as it executes. + +.Example +Activate.ps1 -VenvDir C:\Users\MyUser\Common\.venv +Activates the Python virtual environment located in the specified location. + +.Example +Activate.ps1 -Prompt "MyPython" +Activates the Python virtual environment that contains the Activate.ps1 script, +and prefixes the current prompt with the specified string (surrounded in +parentheses) while the virtual environment is active. + +.Notes +On Windows, it may be required to enable this Activate.ps1 script by setting the +execution policy for the user. You can do this by issuing the following PowerShell +command: + +PS C:\> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser + +For more information on Execution Policies: +https://go.microsoft.com/fwlink/?LinkID=135170 + +#> +Param( + [Parameter(Mandatory = $false)] + [String] + $VenvDir, + [Parameter(Mandatory = $false)] + [String] + $Prompt +) + +<# Function declarations --------------------------------------------------- #> + +<# +.Synopsis +Remove all shell session elements added by the Activate script, including the +addition of the virtual environment's Python executable from the beginning of +the PATH variable. + +.Parameter NonDestructive +If present, do not remove this function from the global namespace for the +session. + +#> +function global:deactivate ([switch]$NonDestructive) { + # Revert to original values + + # The prior prompt: + if (Test-Path -Path Function:_OLD_VIRTUAL_PROMPT) { + Copy-Item -Path Function:_OLD_VIRTUAL_PROMPT -Destination Function:prompt + Remove-Item -Path Function:_OLD_VIRTUAL_PROMPT + } + + # The prior PYTHONHOME: + if (Test-Path -Path Env:_OLD_VIRTUAL_PYTHONHOME) { + Copy-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME -Destination Env:PYTHONHOME + Remove-Item -Path Env:_OLD_VIRTUAL_PYTHONHOME + } + + # The prior PATH: + if (Test-Path -Path Env:_OLD_VIRTUAL_PATH) { + Copy-Item -Path Env:_OLD_VIRTUAL_PATH -Destination Env:PATH + Remove-Item -Path Env:_OLD_VIRTUAL_PATH + } + + # Just remove the VIRTUAL_ENV altogether: + if (Test-Path -Path Env:VIRTUAL_ENV) { + Remove-Item -Path env:VIRTUAL_ENV + } + + # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether: + if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) { + Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force + } + + # Leave deactivate function in the global namespace if requested: + if (-not $NonDestructive) { + Remove-Item -Path function:deactivate + } +} + +<# +.Description +Get-PyVenvConfig parses the values from the pyvenv.cfg file located in the +given folder, and returns them in a map. + +For each line in the pyvenv.cfg file, if that line can be parsed into exactly +two strings separated by `=` (with any amount of whitespace surrounding the =) +then it is considered a `key = value` line. The left hand string is the key, +the right hand is the value. + +If the value starts with a `'` or a `"` then the first and last character is +stripped from the value before being captured. + +.Parameter ConfigDir +Path to the directory that contains the `pyvenv.cfg` file. +#> +function Get-PyVenvConfig( + [String] + $ConfigDir +) { + Write-Verbose "Given ConfigDir=$ConfigDir, obtain values in pyvenv.cfg" + + # Ensure the file exists, and issue a warning if it doesn't (but still allow the function to continue). + $pyvenvConfigPath = Join-Path -Resolve -Path $ConfigDir -ChildPath 'pyvenv.cfg' -ErrorAction Continue + + # An empty map will be returned if no config file is found. + $pyvenvConfig = @{ } + + if ($pyvenvConfigPath) { + + Write-Verbose "File exists, parse `key = value` lines" + $pyvenvConfigContent = Get-Content -Path $pyvenvConfigPath + + $pyvenvConfigContent | ForEach-Object { + $keyval = $PSItem -split "\s*=\s*", 2 + if ($keyval[0] -and $keyval[1]) { + $val = $keyval[1] + + # Remove extraneous quotations around a string value. + if ("'""".Contains($val.Substring(0, 1))) { + $val = $val.Substring(1, $val.Length - 2) + } + + $pyvenvConfig[$keyval[0]] = $val + Write-Verbose "Adding Key: '$($keyval[0])'='$val'" + } + } + } + return $pyvenvConfig +} + + +<# Begin Activate script --------------------------------------------------- #> + +# Determine the containing directory of this script +$VenvExecPath = Split-Path -Parent $MyInvocation.MyCommand.Definition +$VenvExecDir = Get-Item -Path $VenvExecPath + +Write-Verbose "Activation script is located in path: '$VenvExecPath'" +Write-Verbose "VenvExecDir Fullname: '$($VenvExecDir.FullName)" +Write-Verbose "VenvExecDir Name: '$($VenvExecDir.Name)" + +# Set values required in priority: CmdLine, ConfigFile, Default +# First, get the location of the virtual environment, it might not be +# VenvExecDir if specified on the command line. +if ($VenvDir) { + Write-Verbose "VenvDir given as parameter, using '$VenvDir' to determine values" +} +else { + Write-Verbose "VenvDir not given as a parameter, using parent directory name as VenvDir." + $VenvDir = $VenvExecDir.Parent.FullName.TrimEnd("\\/") + Write-Verbose "VenvDir=$VenvDir" +} + +# Next, read the `pyvenv.cfg` file to determine any required value such +# as `prompt`. +$pyvenvCfg = Get-PyVenvConfig -ConfigDir $VenvDir + +# Next, set the prompt from the command line, or the config file, or +# just use the name of the virtual environment folder. +if ($Prompt) { + Write-Verbose "Prompt specified as argument, using '$Prompt'" +} +else { + Write-Verbose "Prompt not specified as argument to script, checking pyvenv.cfg value" + if ($pyvenvCfg -and $pyvenvCfg['prompt']) { + Write-Verbose " Setting based on value in pyvenv.cfg='$($pyvenvCfg['prompt'])'" + $Prompt = $pyvenvCfg['prompt']; + } + else { + Write-Verbose " Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virutal environment)" + Write-Verbose " Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'" + $Prompt = Split-Path -Path $venvDir -Leaf + } +} + +Write-Verbose "Prompt = '$Prompt'" +Write-Verbose "VenvDir='$VenvDir'" + +# Deactivate any currently active virtual environment, but leave the +# deactivate function in place. +deactivate -nondestructive + +# Now set the environment variable VIRTUAL_ENV, used by many tools to determine +# that there is an activated venv. +$env:VIRTUAL_ENV = $VenvDir + +if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) { + + Write-Verbose "Setting prompt to '$Prompt'" + + # Set the prompt to include the env name + # Make sure _OLD_VIRTUAL_PROMPT is global + function global:_OLD_VIRTUAL_PROMPT { "" } + Copy-Item -Path function:prompt -Destination function:_OLD_VIRTUAL_PROMPT + New-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Description "Python virtual environment prompt prefix" -Scope Global -Option ReadOnly -Visibility Public -Value $Prompt + + function global:prompt { + Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) " + _OLD_VIRTUAL_PROMPT + } +} + +# Clear PYTHONHOME +if (Test-Path -Path Env:PYTHONHOME) { + Copy-Item -Path Env:PYTHONHOME -Destination Env:_OLD_VIRTUAL_PYTHONHOME + Remove-Item -Path Env:PYTHONHOME +} + +# Add the venv to the PATH +Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH +$Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH" + +# SIG # Begin signature block +# MIIc+AYJKoZIhvcNAQcCoIIc6TCCHOUCAQExDzANBglghkgBZQMEAgEFADB5Bgor +# BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG +# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCAwnDYwEHaCQq0n +# 8NAvsN7H7BO7/48rXCNwrg891FS5vaCCC38wggUwMIIEGKADAgECAhAECRgbX9W7 +# ZnVTQ7VvlVAIMA0GCSqGSIb3DQEBCwUAMGUxCzAJBgNVBAYTAlVTMRUwEwYDVQQK +# EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xJDAiBgNV +# BAMTG0RpZ2lDZXJ0IEFzc3VyZWQgSUQgUm9vdCBDQTAeFw0xMzEwMjIxMjAwMDBa +# Fw0yODEwMjIxMjAwMDBaMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2Vy +# dCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lD +# ZXJ0IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwggEiMA0GCSqGSIb3 +# DQEBAQUAA4IBDwAwggEKAoIBAQD407Mcfw4Rr2d3B9MLMUkZz9D7RZmxOttE9X/l +# qJ3bMtdx6nadBS63j/qSQ8Cl+YnUNxnXtqrwnIal2CWsDnkoOn7p0WfTxvspJ8fT +# eyOU5JEjlpB3gvmhhCNmElQzUHSxKCa7JGnCwlLyFGeKiUXULaGj6YgsIJWuHEqH +# CN8M9eJNYBi+qsSyrnAxZjNxPqxwoqvOf+l8y5Kh5TsxHM/q8grkV7tKtel05iv+ +# bMt+dDk2DZDv5LVOpKnqagqrhPOsZ061xPeM0SAlI+sIZD5SlsHyDxL0xY4PwaLo +# LFH3c7y9hbFig3NBggfkOItqcyDQD2RzPJ6fpjOp/RnfJZPRAgMBAAGjggHNMIIB +# yTASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUEDDAK +# BggrBgEFBQcDAzB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6Ly9v +# Y3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMuZGln +# aWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0fBHow +# eDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJl +# ZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp +# Z2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBPBgNVHSAESDBGMDgGCmCGSAGG/WwA +# AgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAK +# BghghkgBhv1sAzAdBgNVHQ4EFgQUWsS5eyoKo6XqcQPAYPkt9mV1DlgwHwYDVR0j +# BBgwFoAUReuir/SSy4IxLVGLp6chnfNtyA8wDQYJKoZIhvcNAQELBQADggEBAD7s +# DVoks/Mi0RXILHwlKXaoHV0cLToaxO8wYdd+C2D9wz0PxK+L/e8q3yBVN7Dh9tGS +# dQ9RtG6ljlriXiSBThCk7j9xjmMOE0ut119EefM2FAaK95xGTlz/kLEbBw6RFfu6 +# r7VRwo0kriTGxycqoSkoGjpxKAI8LpGjwCUR4pwUR6F6aGivm6dcIFzZcbEMj7uo +# +MUSaJ/PQMtARKUT8OZkDCUIQjKyNookAv4vcn4c10lFluhZHen6dGRrsutmQ9qz +# sIzV6Q3d9gEgzpkxYz0IGhizgZtPxpMQBvwHgfqL2vmCSfdibqFT+hKUGIUukpHq +# aGxEMrJmoecYpJpkUe8wggZHMIIFL6ADAgECAhADPtXtoGXRuMkd/PkqbJvYMA0G +# CSqGSIb3DQEBCwUAMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ +# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lDZXJ0 +# IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwHhcNMTgxMjE4MDAwMDAw +# WhcNMjExMjIyMTIwMDAwWjCBgzELMAkGA1UEBhMCVVMxFjAUBgNVBAgTDU5ldyBI +# YW1wc2hpcmUxEjAQBgNVBAcTCVdvbGZlYm9ybzEjMCEGA1UEChMaUHl0aG9uIFNv +# ZnR3YXJlIEZvdW5kYXRpb24xIzAhBgNVBAMTGlB5dGhvbiBTb2Z0d2FyZSBGb3Vu +# ZGF0aW9uMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAqr2kS7J1uW7o +# JRxlsdrETAjKarfoH5TI8PWST6Yb2xPooP7vHT4iaVXyL5Lze1f53Jw67Sp+u524 +# fJXf30qHViEWxumy2RWG0nciU2d+mMqzjlaAWSZNF0u4RcvyDJokEV0RUOqI5CG5 +# zPI3W9uQ6LiUk3HCYW6kpH177A5T3pw/Po8O8KErJGn1anaqtIICq99ySxrMad/2 +# hPMBRf6Ndah7f7HPn1gkSSTAoejyuqF5h+B0qI4+JK5+VLvz659VTbAWJsYakkxZ +# xVWYpFv4KeQSSwoo0DzMvmERsTzNvVBMWhu9OriJNg+QfFmf96zVTu93cZ+r7xMp +# bXyfIOGKhHMaRuZ8ihuWIx3gI9WHDFX6fBKR8+HlhdkaiBEWIsXRoy+EQUyK7zUs +# +FqOo2sRYttbs8MTF9YDKFZwyPjn9Wn+gLGd5NUEVyNvD9QVGBEtN7vx87bduJUB +# 8F4DylEsMtZTfjw/au6AmOnmneK5UcqSJuwRyZaGNk7y3qj06utx+HTTqHgi975U +# pxfyrwAqkovoZEWBVSpvku8PVhkBXcLmNe6MEHlFiaMoiADAeKmX5RFRkN+VrmYG +# Tg4zajxfdHeIY8TvLf48tTfmnQJd98geJQv/01NUy/FxuwqAuTkaez5Nl1LxP0Cp +# THhghzO4FRD4itT2wqTh4jpojw9QZnsCAwEAAaOCAcUwggHBMB8GA1UdIwQYMBaA +# FFrEuXsqCqOl6nEDwGD5LfZldQ5YMB0GA1UdDgQWBBT8Kr9+1L6s84KcpM97IgE7 +# uI8H8jAOBgNVHQ8BAf8EBAMCB4AwEwYDVR0lBAwwCgYIKwYBBQUHAwMwdwYDVR0f +# BHAwbjA1oDOgMYYvaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL3NoYTItYXNzdXJl +# ZC1jcy1nMS5jcmwwNaAzoDGGL2h0dHA6Ly9jcmw0LmRpZ2ljZXJ0LmNvbS9zaGEy +# LWFzc3VyZWQtY3MtZzEuY3JsMEwGA1UdIARFMEMwNwYJYIZIAYb9bAMBMCowKAYI +# KwYBBQUHAgEWHGh0dHBzOi8vd3d3LmRpZ2ljZXJ0LmNvbS9DUFMwCAYGZ4EMAQQB +# MIGEBggrBgEFBQcBAQR4MHYwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2lj +# ZXJ0LmNvbTBOBggrBgEFBQcwAoZCaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29t +# L0RpZ2lDZXJ0U0hBMkFzc3VyZWRJRENvZGVTaWduaW5nQ0EuY3J0MAwGA1UdEwEB +# /wQCMAAwDQYJKoZIhvcNAQELBQADggEBAEt1oS21X0axiafPjyY+vlYqjWKuUu/Y +# FuYWIEq6iRRaFabNDhj9RBFQF/aJiE5msrQEOfAD6/6gVSH91lZWBqg6NEeG9T9S +# XbiAPvJ9CEWFsdkXUrjbWhvCnuZ7kqUuU5BAumI1QRbpYgZL3UA+iZXkmjbGh1ln +# 8rUhWIxbBYL4Sg2nqpB44p7CUFYkPj/MbwU2gvBV2pXjj5WaskoZtsACMv5g42BN +# oVLoRAi+ev6s07POt+JtHRIm87lTyuc8wh0swTPUwksKbLU1Zdj9CpqtzXnuVE0w +# 50exJvRSK3Vt4g+0vigpI3qPmDdpkf9+4Mvy0XMNcqrthw20R+PkIlMxghDPMIIQ +# ywIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkw +# FwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdpQ2VydCBTSEEy +# IEFzc3VyZWQgSUQgQ29kZSBTaWduaW5nIENBAhADPtXtoGXRuMkd/PkqbJvYMA0G +# CWCGSAFlAwQCAQUAoIGYMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisG +# AQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMCwGCisGAQQBgjcCAQwxHjAcoBqAGABQ +# AHkAdABoAG8AbgAgADMALgA5AC4ANjAvBgkqhkiG9w0BCQQxIgQgBrni4mcRv7sM +# JHsxpROjRopOz2wuQVrJnn+lD7X7y+gwDQYJKoZIhvcNAQEBBQAEggIAKBxtIIh2 +# APcTqLi9A0nTuTBMVUsNOQNQzSI9fW92jLmXUh0OGygpOMC9GiVVRnHNGmCWt9FV +# pMkolylPuI7wj08VFv5xvsnWo9EKM2+M0zZ1fN+/zNDvrRPKmhUTQ/fGIP9OWF3x +# qbUCGSXrzVf/wSvYmhdBXa7pTrivIx8JOS8fhK5dqSiCmtJOPQ45ZEFNzfgB5i9e +# 9lfNQ0wXKfKHo2zdqS19VEbuIUN8GjSlos7rGHP20aMjb0ZgKWBkYHHm4yNAgJCU +# AJ8K+mL2+KRJDyxwH1oFjgkFKAvEHMVo8by3TigZIxmIkNlYBYx3oh7S3wgKKtNf +# wZqX6/iDYOBmj49CxOEfoN4jtg5kg1slzbham+EPAE2pkNmg+RMkF0j9lJ5KTWrt +# tUZvWJI17UQV0bRlbp4bYiI7OxGDD3LNU1iQo69J3q8rFc+yyplD7lJzKb7h/mH/ +# oMBa6TVHNBuSBSMGLN6xOoshcwWMo0hhfdOqyjFNgdMHO8cEwXGhwJFPimXXt+NW +# KeKaW9i7dSzt1uNnqNXqXauk5A4upOxLceMFhmnoUwcsyxRxSFrti+uyUVMXOs1a +# Q8YyQZFfjy5CeOjq7ohDbBRarX5JwJrkB/BYya6TA9SKfRYwIxfiwYFf6yGLrjAy +# E0Qjhz5Np39AYpfcaWk31MeLse8NVtgVPPmhgg1+MIINegYKKwYBBAGCNwMDATGC +# DWowgg1mBgkqhkiG9w0BBwKggg1XMIINUwIBAzEPMA0GCWCGSAFlAwQCAQUAMHgG +# CyqGSIb3DQEJEAEEoGkEZzBlAgEBBglghkgBhv1sBwEwMTANBglghkgBZQMEAgEF +# AAQgUVAItwy7RQCrM4tGC7KCANd0O7DgaULOpzirVGSU8QMCEQDLPomRSCQZjdG/ +# GAILYuAXGA8yMDIxMDYyODE1MzMxNVqgggo3MIIE/jCCA+agAwIBAgIQDUJK4L46 +# iP9gQCHOFADw3TANBgkqhkiG9w0BAQsFADByMQswCQYDVQQGEwJVUzEVMBMGA1UE +# ChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYD +# VQQDEyhEaWdpQ2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBMB4X +# DTIxMDEwMTAwMDAwMFoXDTMxMDEwNjAwMDAwMFowSDELMAkGA1UEBhMCVVMxFzAV +# BgNVBAoTDkRpZ2lDZXJ0LCBJbmMuMSAwHgYDVQQDExdEaWdpQ2VydCBUaW1lc3Rh +# bXAgMjAyMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMLmYYRnxYr1 +# DQikRcpja1HXOhFCvQp1dU2UtAxQtSYQ/h3Ib5FrDJbnGlxI70Tlv5thzRWRYlq4 +# /2cLnGP9NmqB+in43Stwhd4CGPN4bbx9+cdtCT2+anaH6Yq9+IRdHnbJ5MZ2djpT +# 0dHTWjaPxqPhLxs6t2HWc+xObTOKfF1FLUuxUOZBOjdWhtyTI433UCXoZObd048v +# V7WHIOsOjizVI9r0TXhG4wODMSlKXAwxikqMiMX3MFr5FK8VX2xDSQn9JiNT9o1j +# 6BqrW7EdMMKbaYK02/xWVLwfoYervnpbCiAvSwnJlaeNsvrWY4tOpXIc7p96AXP4 +# Gdb+DUmEvQECAwEAAaOCAbgwggG0MA4GA1UdDwEB/wQEAwIHgDAMBgNVHRMBAf8E +# AjAAMBYGA1UdJQEB/wQMMAoGCCsGAQUFBwMIMEEGA1UdIAQ6MDgwNgYJYIZIAYb9 +# bAcBMCkwJwYIKwYBBQUHAgEWG2h0dHA6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAf +# BgNVHSMEGDAWgBT0tuEgHf4prtLkYaWyoiWyyBc1bjAdBgNVHQ4EFgQUNkSGjqS6 +# sGa+vCgtHUQ23eNqerwwcQYDVR0fBGowaDAyoDCgLoYsaHR0cDovL2NybDMuZGln +# aWNlcnQuY29tL3NoYTItYXNzdXJlZC10cy5jcmwwMqAwoC6GLGh0dHA6Ly9jcmw0 +# LmRpZ2ljZXJ0LmNvbS9zaGEyLWFzc3VyZWQtdHMuY3JsMIGFBggrBgEFBQcBAQR5 +# MHcwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBPBggrBgEF +# BQcwAoZDaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0U0hBMkFz +# c3VyZWRJRFRpbWVzdGFtcGluZ0NBLmNydDANBgkqhkiG9w0BAQsFAAOCAQEASBzc +# temaI7znGucgDo5nRv1CclF0CiNHo6uS0iXEcFm+FKDlJ4GlTRQVGQd58NEEw4bZ +# O73+RAJmTe1ppA/2uHDPYuj1UUp4eTZ6J7fz51Kfk6ftQ55757TdQSKJ+4eiRgNO +# /PT+t2R3Y18jUmmDgvoaU+2QzI2hF3MN9PNlOXBL85zWenvaDLw9MtAby/Vh/HUI +# AHa8gQ74wOFcz8QRcucbZEnYIpp1FUL1LTI4gdr0YKK6tFL7XOBhJCVPst/JKahz +# Q1HavWPWH1ub9y4bTxMd90oNcX6Xt/Q/hOvB46NJofrOp79Wz7pZdmGJX36ntI5n +# ePk2mOHLKNpbh6aKLzCCBTEwggQZoAMCAQICEAqhJdbWMht+QeQF2jaXwhUwDQYJ +# KoZIhvcNAQELBQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IElu +# YzEZMBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTEkMCIGA1UEAxMbRGlnaUNlcnQg +# QXNzdXJlZCBJRCBSb290IENBMB4XDTE2MDEwNzEyMDAwMFoXDTMxMDEwNzEyMDAw +# MFowcjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE +# CxMQd3d3LmRpZ2ljZXJ0LmNvbTExMC8GA1UEAxMoRGlnaUNlcnQgU0hBMiBBc3N1 +# cmVkIElEIFRpbWVzdGFtcGluZyBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +# AQoCggEBAL3QMu5LzY9/3am6gpnFOVQoV7YjSsQOB0UzURB90Pl9TWh+57ag9I2z +# iOSXv2MhkJi/E7xX08PhfgjWahQAOPcuHjvuzKb2Mln+X2U/4Jvr40ZHBhpVfgsn +# fsCi9aDg3iI/Dv9+lfvzo7oiPhisEeTwmQNtO4V8CdPuXciaC1TjqAlxa+DPIhAP +# dc9xck4Krd9AOly3UeGheRTGTSQjMF287DxgaqwvB8z98OpH2YhQXv1mblZhJymJ +# hFHmgudGUP2UKiyn5HU+upgPhH+fMRTWrdXyZMt7HgXQhBlyF/EXBu89zdZN7wZC +# /aJTKk+FHcQdPK/P2qwQ9d2srOlW/5MCAwEAAaOCAc4wggHKMB0GA1UdDgQWBBT0 +# tuEgHf4prtLkYaWyoiWyyBc1bjAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd +# 823IDzASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUE +# DDAKBggrBgEFBQcDCDB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6 +# Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMu +# ZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0f +# BHoweDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNz +# dXJlZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29t +# L0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBQBgNVHSAESTBHMDgGCmCGSAGG +# /WwAAgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQ +# UzALBglghkgBhv1sBwEwDQYJKoZIhvcNAQELBQADggEBAHGVEulRh1Zpze/d2nyq +# Y3qzeM8GN0CE70uEv8rPAwL9xafDDiBCLK938ysfDCFaKrcFNB1qrpn4J6Jmvwmq +# YN92pDqTD/iy0dh8GWLoXoIlHsS6HHssIeLWWywUNUMEaLLbdQLgcseY1jxk5R9I +# EBhfiThhTWJGJIdjjJFSLK8pieV4H9YLFKWA1xJHcLN11ZOFk362kmf7U2GJqPVr +# lsD0WGkNfMgBsbkodbeZY4UijGHKeZR+WfyMD+NvtQEmtmyl7odRIeRYYJu6DC0r +# baLEfrvEJStHAgh8Sa4TtuF8QkIoxhhWz0E0tmZdtnR79VYzIi8iNrJLokqV2PWm +# jlIxggKGMIICggIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNl +# cnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdp +# Q2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBAhANQkrgvjqI/2BA +# Ic4UAPDdMA0GCWCGSAFlAwQCAQUAoIHRMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0B +# CRABBDAcBgkqhkiG9w0BCQUxDxcNMjEwNjI4MTUzMzE1WjArBgsqhkiG9w0BCRAC +# DDEcMBowGDAWBBTh14Ko4ZG+72vKFpG1qrSUpiSb8zAvBgkqhkiG9w0BCQQxIgQg +# U63BaTxWvK6IjoVixdUxR2Ka9ngnAWl8TjG38EljW2IwNwYLKoZIhvcNAQkQAi8x +# KDAmMCQwIgQgsxCQBrwK2YMHkVcp4EQDQVyD4ykrYU8mlkyNNXHs9akwDQYJKoZI +# hvcNAQEBBQAEggEAmed9c1/5eDuMSWHIIs7oR1RWaY6OR4PjxqCkybJRvoGl8wO1 +# WmUE58PVZfTNtho02cKeP+HNsyohxFp78bBXwObFNC97vbmKR3U7ANBnu3iEE/hD +# V3M5RD1BN4SE8yzfRlN4DB5H8rgvArWpjO9JedbVrBKrEe4FwtU8vbQhdAyFMGv5 +# ITWLQgiDJOvAOjfC014JKRgnTMgY1JntNHO1ny2dgkYYql7kO7Jbgu3h/lox/lF2 +# 1Sfonu9hDsv1121CatHRMU8B3kDeiF2P9/ifu5e0UULd0mTsMF7CIUs1/TNX0bAp +# A6DuV3o0VVOjsfOSgQUiz/nMxVmQoWFv2sNc3w== +# SIG # End signature block diff --git a/Rahul/task4/pyvenv3.9/Scripts/activate b/Rahul/task4/pyvenv3.9/Scripts/activate new file mode 100644 index 00000000..f4b9ddde --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Scripts/activate @@ -0,0 +1,66 @@ +# This file must be used with "source bin/activate" *from bash* +# you cannot run it directly + +deactivate () { + # reset old environment variables + if [ -n "${_OLD_VIRTUAL_PATH:-}" ] ; then + PATH="${_OLD_VIRTUAL_PATH:-}" + export PATH + unset _OLD_VIRTUAL_PATH + fi + if [ -n "${_OLD_VIRTUAL_PYTHONHOME:-}" ] ; then + PYTHONHOME="${_OLD_VIRTUAL_PYTHONHOME:-}" + export PYTHONHOME + unset _OLD_VIRTUAL_PYTHONHOME + fi + + # 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:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null + fi + + if [ -n "${_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="D:\Glugle\pyvenv3.9" +export VIRTUAL_ENV + +_OLD_VIRTUAL_PATH="$PATH" +PATH="$VIRTUAL_ENV/Scripts:$PATH" +export PATH + +# unset PYTHONHOME if set +# this will fail if PYTHONHOME is set to the empty string (which is bad anyway) +# could use `if (set -u; : $PYTHONHOME) ;` in bash +if [ -n "${PYTHONHOME:-}" ] ; then + _OLD_VIRTUAL_PYTHONHOME="${PYTHONHOME:-}" + unset PYTHONHOME +fi + +if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then + _OLD_VIRTUAL_PS1="${PS1:-}" + PS1="(pyvenv3.9) ${PS1:-}" + export PS1 +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:-}" -o -n "${ZSH_VERSION:-}" ] ; then + hash -r 2> /dev/null +fi diff --git a/Rahul/task4/pyvenv3.9/Scripts/activate.bat b/Rahul/task4/pyvenv3.9/Scripts/activate.bat new file mode 100644 index 00000000..4fbab1bb --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Scripts/activate.bat @@ -0,0 +1,33 @@ +@echo off + +rem This file is UTF-8 encoded, so we need to update the current code page while executing it +for /f "tokens=2 delims=:." %%a in ('"%SystemRoot%\System32\chcp.com"') do ( + set _OLD_CODEPAGE=%%a +) +if defined _OLD_CODEPAGE ( + "%SystemRoot%\System32\chcp.com" 65001 > nul +) + +set VIRTUAL_ENV=D:\Glugle\pyvenv3.9 + +if not defined PROMPT set PROMPT=$P$G + +if defined _OLD_VIRTUAL_PROMPT set PROMPT=%_OLD_VIRTUAL_PROMPT% +if defined _OLD_VIRTUAL_PYTHONHOME set PYTHONHOME=%_OLD_VIRTUAL_PYTHONHOME% + +set _OLD_VIRTUAL_PROMPT=%PROMPT% +set PROMPT=(pyvenv3.9) %PROMPT% + +if defined PYTHONHOME set _OLD_VIRTUAL_PYTHONHOME=%PYTHONHOME% +set PYTHONHOME= + +if defined _OLD_VIRTUAL_PATH set PATH=%_OLD_VIRTUAL_PATH% +if not defined _OLD_VIRTUAL_PATH set _OLD_VIRTUAL_PATH=%PATH% + +set PATH=%VIRTUAL_ENV%\Scripts;%PATH% + +:END +if defined _OLD_CODEPAGE ( + "%SystemRoot%\System32\chcp.com" %_OLD_CODEPAGE% > nul + set _OLD_CODEPAGE= +) diff --git a/Rahul/task4/pyvenv3.9/Scripts/deactivate.bat b/Rahul/task4/pyvenv3.9/Scripts/deactivate.bat new file mode 100644 index 00000000..1205c618 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/Scripts/deactivate.bat @@ -0,0 +1,21 @@ +@echo off + +if defined _OLD_VIRTUAL_PROMPT ( + set "PROMPT=%_OLD_VIRTUAL_PROMPT%" +) +set _OLD_VIRTUAL_PROMPT= + +if defined _OLD_VIRTUAL_PYTHONHOME ( + set "PYTHONHOME=%_OLD_VIRTUAL_PYTHONHOME%" + set _OLD_VIRTUAL_PYTHONHOME= +) + +if defined _OLD_VIRTUAL_PATH ( + set "PATH=%_OLD_VIRTUAL_PATH%" +) + +set _OLD_VIRTUAL_PATH= + +set VIRTUAL_ENV= + +:END diff --git a/Rahul/task4/pyvenv3.9/Scripts/flask.exe b/Rahul/task4/pyvenv3.9/Scripts/flask.exe new file mode 100644 index 0000000000000000000000000000000000000000..eda3f06ae0e091d54619f2d7b5ff37de2d6ae700 GIT binary patch literal 106336 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 c^bF9y>2e+pqq7i;1DYXATM literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/nltk.exe b/Rahul/task4/pyvenv3.9/Scripts/nltk.exe new file mode 100644 index 0000000000000000000000000000000000000000..83e6335bacd4738921bbcc763006be150e4077f5 GIT binary patch literal 106333 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/normalizer.exe b/Rahul/task4/pyvenv3.9/Scripts/normalizer.exe new file mode 100644 index 0000000000000000000000000000000000000000..8a6223ab873894c658c1f3f285e7f006946d194c GIT binary patch literal 106372 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/pip3.9.exe b/Rahul/task4/pyvenv3.9/Scripts/pip3.9.exe new file mode 100644 index 0000000000000000000000000000000000000000..4ed3f35ea2276f0a57e502058a43156e3fde8fde GIT binary patch literal 106349 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/pip3.exe b/Rahul/task4/pyvenv3.9/Scripts/pip3.exe new file mode 100644 index 0000000000000000000000000000000000000000..4ed3f35ea2276f0a57e502058a43156e3fde8fde GIT binary patch literal 106349 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/python.exe b/Rahul/task4/pyvenv3.9/Scripts/python.exe new file mode 100644 index 0000000000000000000000000000000000000000..7885ec4fa9f470f967a2445c36924fecd95b9ca8 GIT binary patch literal 543464 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ֺ@G@vMG(bx!L#Y%NXZ~=moD8plfR;{+RmHM+) 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 z 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

    LS;f( zHB8d%?ezO6$dHyZy^6>0^XNo#Wi6UM&uv#9Y@tyWwr}e78JU(^|SB<_Y(E2+zC9B?3LPISQhCl|0G02wc>Wd>5h5ybU59G{Wx8Ex-_ad z-H|ALh11mo2b_-A^{(6#WwHFRp1wKKleJSPR<7;ia_)1aBRQ4|Cf*+^E0r9^;O#IT zoaMijcw^zp`MjK<7=gvb{QPrwLoy2qBOf+3Hes+qm%lp&OqwC8PD8d4Hb2%UFgon&!H9k{i zO{PwjmJsQmWJ_8*L^6mEF&VHm?9Pb{wPLB9=uZ5xqJAKuW~1#Q;U7}(sJT<(w|?cI zQ`eZhku+)1U6$`1Yk}0VX>+RMz)Jf*b4$|zMw@ef*qa0mu)`|AEWzq9tl)BABrE5`o$-9{w%Napa0a( zb26IFr=tOBPxT&EzwW(3BbQuuFz8&=n5>uX)291#M(3&H=}Quy9_ak$-wdGpyLoJ?iX#iDz?aJJM6<@8?u!qMsDkt?L>xoGLh(Wspl@yw;bn)Fp z+pzahoAPNK4bR<^MgM&ed-H82K6TfS&pQkw@>D~qRr#EI+_nP%27YbuYlC0s+H6Q- zeW#_2D`PZpP|v1TJ*a!qgeSCHb^?(nfWwwr_6&UOC!Wh!pYSd%t^2@bmAM?Q##3?r zOoq0)agP97C=-{BHT-6w>w{I;jkxk>k~&JmF(OH;(MU}q@^#CO?eyThTKo_%XKm1cuZ@hwg(y1Oy(mw{%~pGby4~to_a&R7 zqF;_BPy@N8Qn#dEdVzY5Wx7308ml8?p5VdL$Gi9&l2l02GtB~3`6l-TomL{*c>Sw> zm1^7-`dRw!vdn|LKTYC!l}6+(96ir{`eH%mv^^2l85L7_jPz-wd%G$+%AGI2u{*#m zCuuJLw;Upo9J%i0>dP9eu3e>;9Pa-kwCOE2Stpj51ZX^+oO%v(*faOf_@T-n-ooX8 z;=}OJB9eN#W3@QX-T|+mi3+WUaB>$(W=4hl<7|}?9)lZ0ui#<5yKSgI=jn+lcO>;+ z;?+M&>sNH`-I>~fL({6!`hA+0h>m-LIoPcFs53wUd&?|&X5KUOnR(BQlz#6|q1RvJ zQ7H7NC{(hrEDDLT!Pg|}rFk@p&#R(Q_e`*$CQaXZ<^FmSY0h$CQ2HFVoqH*2jkaz% zj50x%#8cD_zV5t_4yNz3?Badj006kbBpGyjoBsGqJ_;j2x7B~ucAtEiLf|DU7f7r# z=Fn6b3DdI2TQx6nV?F*>XIU(~RD0@2z(Y+b8H3*J@X&m$wKXd$>$bsb>X% zs}2k4UdZt;z#M>&(P8C=vYl3KoXQe&tIs(<+6#l^t~8|O_!Ja)Q}V)u(g&hiAi^=l z?owYkw8VXC!&U&DFLjpeQCMCB_NLUyDhbd2A(sDn0xUekWeMZw7tA$d?$!Ju+Cr|G zPNe>B+BhArjZZI<6NJu4%<9DAxzO+a3bDqXUbr_g%(%bPSh;Js@!gK&dw9s>p|vOK zj}vjSZ$o@|e`M>t-GjL*p=YZ?-mA87$x zD4}mqWCYTkslUr2$*CUn#RMp*HS>a%q8s7iU?75^b~MJ;bSu(9*t zgFM^QkM0$RqoX#ryp{_yZs{CS2#pmYO;)}u>?MAK=1s|S88oH%6mJ;!mP?sG1a4se zd8s&c{95XoQWA77FnhT+QJfBRr9)JuIa29Ucv7>X{7!;;s!GnH5=MNavHFH0qqRpMpEIS%^OnhX&-teICwY<&vFU}}TF>ncG7Y4p zHwU<`0!e{ncdV_W&;OYDMCia3KAM}DsNvq{uc(v~1$6H=jiSSWKL~}1vkSK}Kq_7b zqBC`+<8-CQN_RK`N~>=uiOl2~+pC(0BoXY+XnP+(Q3&CletWbxDgA*2&`jW-PL&(o zEnrxhxPo^&lrx}1$&*P15s^DAo7HENns}!$@oJ_QMQ@PexU*3_I;GyuCoWCcUMphs zL=j>|40Y=CoFY8-?yI>%Wc&h7UynA^9jRTSEK(O=oMJ}za%Mg<-B@`;VFr4M(|2|j z?9|bRb&Mz+nNHO^7XUST=fAnXh%1&;39iur$*pUs;qTVh^}>C2Y}Cf&4zR#hdlJTE z^!KluS6p?aWKzrYyD{Qb4*0;5Jx@E<#GhgPldCC`{2c@2d4^~)r57%1q1l2-KDwfQ|&6_8H`!r zknSp&=Fx^DbhiZUXer(G7%uwjOkaP@x^zfiF?x$<^@mCzL#6N|dN#NEG%uiw zQ#@%p7ybS75luTSd_*h^kS43n3l|A!kqbx~?jJwr zb@$3b;trXiChiw(rZsHwwpwZAk@wZmu^HrL9g1z$&`l56s zwJ@bSrg>w9Z<4uUxHmwh^b4NY=sw(_S~=ESE}vw<ooG%?@9odDfdG!p7)wAn-cea^bA8uesdB}*oNXd| z$HULzWME^i(e4L03AkULAgFo+4r1vg!O~tS!T21aZ9F9eV8tsf=axLS(x2lt5;nf2 zk#Sf?OqlpsR$+s9Br@>A7x{>ku|Cqk2^E!bnA?GTn#y(KoKy%_&nb*@)QEErBUe=A z_*T|3((aQK1uYZgP>a3ZE45fk6}T5uio!4K)rAScBD37NN90X%o`|-C7NdFT;{CnI z6o`OZ+-DHA>}|qHaW?l&){$6_;?a1LbG~cIC*MYpAcxQVX8c&?_4k3Iy2oY8%9Ka7 zaH356Y1L(V+H=56&3ECo-K{cCM%!DI2|89SCyQ6g8YkagIA5<6vLss0s%Cz?b(acc zb(KsKgHNDnINWlu65lTK-U0IAP3+<=MI4oswnDvO{B%yYJ!gAx@fat6#Q9%a^hU zyLs%uZ0FBFCQPTace`fZcDKD}pj47Be&pZi@^%O}h)-~)No zrxelqjHx-kxiuA$B0|`skck}_anqid5r{9yi!TV+!}_mC3OZPHxLdPmHU5f4-vEnl zVr7C&_wg6$$cfT{*g7XbLl{4}+h??=H>psLtGu|v6Ud*DF;hwagE?!N(_>{c(lt5-nH$Z0H?*8;BQFwKyQC$IpbDs!v z+-R&9D%l8#2&)D1It22%!vu02$x=kzx})Q_1ggJX5-qpv5kY$^qUUg8dzp^eCx$0Q z4BxNBa70g-X)s=gC^nMGVBPwL{`p<;6L6h#%J|Su#24$C6ny zwJ3V3)H2CV{3<7UyfU)qK0^4xxiuw`Bjk29rsan+E!XC#8th^HWb)tZj%chPlP{F_ z!@6=0618;YZoW$E3Lm?|iVK`+6S4$xd>G)DMDj#xjSovTs?M7yl2w)I%(1#G!IWk807{#Lw3I61vc{bq^iuY#U?WKIl9M}6{c zy7()51ZUCV$9V$Pb=XN1?@-8FW>Imc&E zGaJ%mDIYGp_A36%8=Tj^(m4Pbec~_^53vpQQg5$KeUV^`4PqGKAmD;w%eUjSof@V0 zF}Vx!mhb0%uD{1j>vr08+nv=$^BgJ8BoNyzEq;`dbUQ$-+7p#@s+zV|kQ?-$6bvS}Gw ziNWb&_a6%55|(R}6aZgCxgUWl4wazAF3|x5^MQbUf6m;R5s^_re}{OMqXZdo(?2rt zcUW^XeXEf#ZLA0@l6s&#u<6wv>acW z$S14a{RjfV__aH6epC7B&dn-w6UU=P!#-NQp;2hq>6VDNi&2!vSCqVb?M|a@6>Zza z4^d;iqv}YnqlKG^E$BW><>Fj;pMZCGb!$b4UZASGM{2&&%X6V>a=LqkxTx4YYDhC; zOoDG^$Pc2bGuc8oBgY|pi=1$$h%nw_U;Yk@XJ}_2I$rvgI--kbs32WDf)B*XBx+`` z8sJ-ZPzH?o_!#c}I{`I!YU7Z5byiAWP8KDaf1a|!&vCHu*$r=aO+A{@sox=0c@p9X z##hVv{vH@Ha;fQjYbJqY-D!3723Nyt)Yk`ui}F>zoXQsxpRT0}327vPS)o8%uj-Ce z+YN5Lv#42rRziBZxI%wB#&RAI=xuy0W~>W3Q+wRE?j9gF^F+$U#XZ!g4t{(?*QR5f&uwj@W7S z{xe+D(PX&KynB#ieg%|<)tEB7N4Q7bBZQ$XUB(|?VgDdIBvYkglwA?Nq#Te^7VZW>@uN<0)2v-iEkPH5+q$XMto z?cCc`e$lD-`2na90-VKO7r8_<8=82D$(5kOR+bPk_gOW6kG{#D$Z1y1tC2}0?XzOH z?DI(kK{a>sD%Ylq?-dYY#9(v?hF#MYefji`)DU8FDfybcOvc};pH3eXs-}-bRgE2o zKvq)G)J#P+uM(_FimS+8O1F`lI7`PTUBNH*Q&iuTopN4uOE*ZVw{w4@(i5iLqm-;1 zOfFx?$FMr|NPLJEz9%)u_>A$VRm}8};mc_^>u2H~FLVOHxR|k-U6ND_Q9lk0CnUXaa1RMLlWf#gldMUwFidW;#hKMBu}EY9|2{uRnDO?`5o^4?#GxW z@4M75?s}gkR(fpz5UI3Sg@RY&z-qZe&pH2NmXRDHtP3x+bAOJp$wFS^#)Z`I>hlBQ z&eF*&?}>gO!07mg!dGJZM=uz$d_<|=XZ)=DrhNPagtdt`O5bT~aem-Dt7Km;EVIFx zUf2K&!0D?h>|9*JZ!HH;^IYNwXXzn6ayb1WbnyuNldpdYq_aX-ROU{@uZQhPVTOhz ztx~6X$7buwVI+UjAr(Yi!E3^iKslm`YYf}6#?Ji902 z+N1-?MN5<&?%}d_(t)+sywbeFyqx`nB~eXARuLH0O6&sJ-5`5bK(39WQ`|WZvSA_7 zF|LEu>RoN{;+qJtzqhymIduA7)q&LU1g=kgiBM1Dd3Z@4V6l^T$pdFbCwK5*#g>&d z)4VU#x;K)q>2u%T6~%v1lEyIT?Wf7aQLJZ=wPm9fJD8(8$O>h&O2Ad~FNLUlV+ZmV zOeS{b%S~Sl(10eyt-&F%C?Kvsd( zF{7phit+A5fugZc_VL^?o?Gw+y-4>U;7bBV=L4@JUTl^walrsx>a=X#9gbk;Nfm!| zcj6Jk*}jEwt1$I5X)({4;de*To^Cnv*N?;$osk2Wh!Tp?i$8+$mKDsYV}9++G1LLd z*#5D`qLrXwd9Zo5%o`*2Ti#CJ!KpBubp7sCuP`vN^pHqyEL|KuyLs}zXR<^`Pg8Oh za^873*`-&i`| zSo9bV%Y`6}pY1bZ%Xo871KZje$Y}i@2^>pd_7gN^3FH&5*@VxUJ+cu2)IH)YVAUe| z*8%Mu(!7hnSKJ{XAM>T0oqIIt4gQYvouUrr#=`8}==A1Bq=MBXuihS`dT{IvryvoA zYKp7B{ZW)*I9;(V;@*V089o)ZJ5$HT(tR9j9~|rSH!@R8aV!{ht%Rt+6d~cRVg&b+ zOUv{+y;4FL8&7U`L!pCdWwjVOH+JBvXs#L=?QeIPCj+dM2_t#Oe`?-Z3Fsnb6!+tk zK2D=ARp;2bRFhrkBv6R&;g?VFHS4WgHUKdBy(=$;ryxrx=#sw)ioRF1p8Sz|o-5Ih zhc2&WJXWuizsb9Fo>F=Kwt7CKf7g=uS^HQ0pYp2s0m-qtJ+ZzfN9bn=+Lt^yMZqc> zuH*;$8EM~_d`my)$@5G4nJm8KM*Z9@&z z_rL3B)%VT%xmoI5qn?}3_A#vTadq>zbL3enUcI<(2$vw^gxI?cw(0j|Og0D}ja`4I ztU~(&3y!o=#&Zb(?kgXr`D;vjUi@SHbK^${-FtViWc(KTA9pIX?6X-$8|+=|bKr0~ zYNXMM-hwHQhbnu+pYR;4`U1z9wASI6VAVHsz7#Ebf!$Y7sr6Kuo^*g%92j*EH5=FJgtusvR_)4L%EcHc(pE*?TvrAF&E z9xQu_J|7N}E8Op&AVJ6L%c@##E>H%k6YK4}%S1P!?zP4d7Mqp`V{JQ(R)^wofATJ= zWzO|^_0>PA;xT%r?BItQPYj(KC#>9#$WVQa2bzdr)iszsTW?U!(wxVol3yXA-u|;{ zCsci6Cva!(AmNydZ56oh{Y*97c0H8@tLA$2 z1&paPRHx`W+d-+LuT!jz{j2z`SH(px`wSi5)d&GsdUo+%>~ z@dx9_al{MP+(uj$P(9p$(z*#{-7OsM(kCpnojJ3wFHunUc_S-@+w2BA*C{DH9zI`JG_YVp4=N;O4&{7;`%B7MbEM$H5+q(d-w3)L zmg|Gor1C1$Tvtkk;rMyYx9w4W#q{zgavjXaFbKi$Y%mOF<;dJERtCFp0?{F$WhHKG9R6Yojh=S7y zMT!hT*z~zZeImn@*~V0PHRlHKAA{Z2Bgz?}4)Oe+#2n-5MygRYqb7P(P(Ft+6;x0K zoL+eg$Z|JKm-1^H>>kagsU?BRimOg(GurQ9}cmT(;O4N6(ZsxX`!YR8vXa=3{#r z?Cpy?6T63&ombFowg>XVa+KsF~P%V7|PEl#ASTK>f1!sZVvB70jop0RjJ`uIfZw8_39 ztRKbAnEeZ4=~E-a)VayjrqkD^)+@<3S|H!{@GY83y{3%_6=FZ|6oh@SWoav8uV^5e z2Ky~QEOBQs@EIal`l1j)QlvZ4$i80Lv4)8KZ5^g@K?ij4AgYZ81@4Jb;&{e3wLw_Q zs<3@C#@jFFtjVcJ6)zr!wlfzOI&_v5>UKCY-AxsDytM}HM|(5HxYOr4c37u@pYs%c zX1VLXsPJy_k~?c+3KPGo9|6~AL~Uh{sz4tBf6)6!)*sS`DJMl_#S5vhnB zJT)~ggAx)ZkPtmGm4A8%po~fR*Z3=}^!mmAbE+f%I@r-pIQH{Siw-r@Qv<1E#peLK z{FLTfS+1jmE$;|BU*ZM`&TrqOuEEng9Xyl{vCIsx#W=q$t3~hL@JCi5>B1B7 zAcwVVvzAi<{|bH9Q9G=OyfdZvXZVN$ZTVladbc0d5t^8A&KYX@_qp?LVM+SQw|%}3 zj8nQ{oe`&nfo+cMJlMMp!8egAotPk5^bTeAYSK1ik?(ye-3es#TGD4Am>YLa1?b9- zuC@}`yR;l{E8;2scp-m9?jf!p*0wb!{w=|~Bh{^rd^XzhNyf$&B=FE1LFdP~M`AVN zCOmU_Db+Z29CBIDRk3F5^$BJonQN9Gus4~`tX?Mv?F1uMQe@dbO+mfgXLtBJ8?ZrN$(_teENSrReR>!c1c zmd#5&VcHv+&yi7fBAuWctr3%r@&`ernt7=_z>u!Z)At#4wFT+A>}i7WpV#u3oCZQb z0WOpOhbR!`*`O%6`Tu(qD7ror5AnwZ4;dWbJ%u*pETc6{;(sEillVReIgKGXLr%u3 z)ryp|q#<;m$O;;P;7sGYT_*AgbRk4Be?(@0QjMlFEp67Uj?@M19zw?{!kB8;FHwZC zF(`CWXV(jzFye{iv8J6!>>QHcjrF}QPPPzbHAy_J2LI`^7--_n3C)-HawXfr#Cy4f zvrfE@`}S)0O`IfRZ%t4;yV}JYx9p6!9wS+U&R26n_OoH?20=2DJUpo_q3nU5+Q1(w z797^stTqn~aQG3OHyJ<1}F<-WozU#1)Mc zv7GPJ{z-mRUN$V2f4$`t-RYLz_z~dVFJ;ZxhdIWgUjTuvxF!++j=OIK%-Bc3`+I@+5oxgjCu3+d zWWN@S-!BzHpOM<-18B2j0r=8%dEyPkf8=x`QS{y29Sq{fgoF16aq7nGAj+z-m(j+; zW3&zxK;&MEkEuS>bq+Ot)~+X!8q=Yg7r^OGMR*ETrv0*M)Nyy18XU`*vW|6b5;`e~ zqEZXI(mTPjqsAp{OzCOm8#e8b5qg0k5*SO!0|T(nXhBXp4n!Mm`$0{}xjH8p|8v_L zGzU7R)#NToxA7xPggCq0`ZTYmy}fq_Gp~v3z3qLWnrEY9#0Q3wtE6PSO$wS$paiyN z7u{)Mwlx0mB0-StR+WJ#`N}Eo_!5=CAWD%i%eGn5DPep8H}yyeVZA}xF;AsB>{j(cbF6gG5k#cApsTeKNevB8Db(*Z;Zl9g3)QnO#7(Jtm zn5arVWmahk5i$_HQZHTC4eM6z;F1VF3C+ysdM987`u)GE9@Sa-6TQA@8B*g zgbmg_Z+9Bg5|x{UPYN3(RP)`lD9>NC2-zCci zM`qUKn4d`ruO#_2~6k zqW;QSA!?cyE`m#v=5%|ZY(*LG%7fRxew^-;`MoWq^saX7Rk zWEqUV)xzJlg8RYv+olYEySX2KTlHD_Ti0Ox4T;_V$^1>e_UCV^tpWV4b^w2y2jVcy zh46{V@Y4SLP4hFw-%t_v@i$fNK>l`$=5G_IP{kuv8?b@=txHR1jN&Jdf#PkI*YuG= z?+VCZ1Y_?lc^7wiWS}{l*a2bLD7JDZ&w;aDQg)7-l~CFwqiwb@HkrRzhqH`Lw16-+ z({63noGmg>O_lGFu1IOIJSb8cz}-HXl$a{`O$d`|I^h$h$ywB?s5f~EPZ^%3b~vdM z!~sq3{k)}9rLWWy0dvGX{c}oAl~q9$YxCS)a3AJE8UCI|o9NEdU2BFCK;g<9wd~`$ zHIPlVsJV=#X?cN1bOcf%O1=5>R zc>!#sSLUDv2QRZ33M*dKmR>kQ3@Yh677X#@iV`H$EqoJKt1io^+h_R?;>TsQ7SY+D zY!uDEh~is`06x+VWB=E8`_}!Sh84gQ|yZwthiRSMV6b@M%JUL-H^D2UNXQ*a-(-ABQ zUA4^z2{pIT2zCb-?@tXw7^-bQL)~wpW_Q{pbf!OFBv!f^*?-?`IWhc~+Dq1N;k-?A1SQXSH!st_u(>#@-&Z zCGt!loY*x)4WYZPOs1~q>b0Q@Y|A_0L;CqFQO@gk_V$EWdV&O%Snt+e&q9%& zfPJAI|2nFG^H-n_#4S$w%QW9C*K)hhQBW%hf#}oWIeP#+L3=o{cY-w|qDNPDh~{97 zU4Li5tmaR21OgaNEB`>3c)Hj~-r(NpuM@?_(PAKQ;%SY(}2GRJHLdR zk-WyLL|3p(46D9~pKuL$FX@8bUt`ttk-X&-_*~w(T5YuleizZX@Zyg?e61C^U`)GiJAw}$iASc$hwt={($*64vB`F(2?#}fsMf-e4f zkCn^_xaZOqA?1Sc`2ksGIDg!>mbjwQWLg^i_YfMb=`+kjD+vL7&r{Fs_mk$K;qj;;YweXV0sfzr!B~#-VL9@KWn$r`W zld$XW64Ls9ph?zR=tf`333{I@rNWSWccvXQ?HkF*NXLI$HXA@9`Q}qHqQUZQDSy!3 zVV0v!c(`mHpV%yw%D&=@vi0EEQuQUNk-Zw{wBncelql+6sY znO+?a-V+Gcym}K%6pZ0}C8!CbuR@dcHyXeOq#NMmW|%gp^K>)aDaeC&+-2JS1{$O* z^?nqXbud!5G+49srma98a%QH(i8o5k^mB?a>@+d-8S$?vg^V66)43?eURN`=Y0O+> zLJ%aN2aQ8cHKT6&S9~m^Fe<&S`o`}EqC@2^%4LSns`C>q&k7&Nu=p#KuY|A^qRild z-^W7;&VC_tXLl)c^};+@bGk#=zOZxkPv}JZT8mA#MENL|;xZ;j9TNY@mH8u{Ek{2N z(!u&__XezaFnz6gGoE1WzO}4&%g(xZurk20c+ZA~sl<#A4YM@C{`IYFx;=Hy!a}Q` zC+7W@clNY z4%z}cVug6j9?I6gX%rj9y8@5qq=zOS1+u|gm&NaU$KXNNk+daKd|6pVKr+t_)W`o) zwiBR&_PKgT)I*O<`{**Y0FQz}vH+`I$O`N>PzxTrlK|Um%Il%(t>mV!lgLD03u#Jx zdHeTO_jB%Ch)J(+y1%Af)EagQT6KrF9NOWRq{F{Etiyi*!Gm`gK-`}mtvbAzOlA#U ze7`N*qxuOO`g57fqnKUne=yV5;9wI_dEgBpW6G@bMVM#?9x-?t*VId5ISM2k%<11 zWin#Ty-(^li5J#ae?P$L>?P_=6hkN&pRbGScU_0fN@NFS^-5SU&U94uHN`*EtIZl5 z9z_9%=Z7~0@ljba5%fFe6B$8@394Vuk`lZJnHpmneGO!cCS#{M zKV0UMxy%IELjnq0&fAPEjVCS`Vmz^cW$tJPLieFnhb^OzeFJo&`{b|N^_v4}<4IhvN1jTn8GSk`b}w5$ zo%)7LK1$n;lv4b5t<0S^sS1|+Iqp&jpoo<-r63MpB1loTWO}@RQi6WgM+el-xtB5_ zd#n;jQ#>~)uKR2VzdCzce}0rus`sK8{K#X#hw!6yQQ=2M>(8mh)J$n)NVu>G6TVNH zk*)I21!mw8Sb4ft?AP{D_ZolfDi8l2k$;zqv6rDLW&!7IR_Q8PYDI4<^R-J31r z6z4tlKUBWS{XLmv2VV;N6#^9Y`=0J~hdPHBm))wzKP5=8_~lHUeLa8Rf;S0*%<8e8tk`& zb~05Ege^NimmK!{m1`?^#MS*dA-U0taECtooF5S4@fhK^oNV*KZ{vS?M8;j`OTI`V zbJ$)jZuw8~A~J3--Dds@6Pp#ZyWxk$@Y}jB%+{2Yf4a2k6tE8p*@3&^iR_!YG|yGJ zc$CkY>8ccAx-}bZ1z+@M!gFWPg3($=oto=&IQ*_~sN!?Nlax@X&UaivFb?iqi*l4pr@uBQB8 zO+Q9R?`zH_M?3OOZp_04xf8j|@ANV+He=K2H$Qj*h* z;_jvXDS5V%4sBMtjczFB3n3U#W*5H6O6k3hfP5^*d6^ZU zcIKttsbE6yK@2Q}_6L|*X~0}j%2=6+-MJzA{Z)K}!4w9|_lipcVRE*-nSKs$jG+B7 zTSHlzdbeUjPKW_~1Nzx9P~QBCP`otkSZZ6&qI!))OIgyi0+#&-kR=K|!4$$`fjg*obVS3|oXx(TtN3)U+;}84J zh#dbvhswhf6VY6g_>s6G?znlZwSv0%$5|wJ>#*g_f9U{Af5NTo?J*~I#kz-t;5q@b zyvt~P7?qQHSd@9VNgitWbOjF?|EBaE((wvBp3(%(X9LVlXjt-<^Azspm*Dk?Ktq%t z_C{wYZxr_D;fd=8@tO+bk%{9})>o=C=#&i&`FFZu(CbFPm~xi7V%cE6Qdj&6iKte) zO7%j|TjMjAnk^q`N2wzr4)JWUkTtZURFEf3{rr{PLIDHI0HJAWTUJ+%VV-oOZ7+F4 z{x0#8dK3Itp%!_#OuVJgXfQ9ef0UbR_l7a}l>gJ-h=Y__{wmHMZOi(3ND)V@d>`|5 zh^!QgTBOoSf*D{VdSFe^|3S#V$BZ3pT5yBuEW|(RQl`_^h^73aIrMe3Zl$P<$)M>mC`#N2#0y)0rwR zS4Qi%U_1jojPBR;mT|j+{DxGnJ;;bJHhKQtug7bP2S^k-NFu+C1gZ~x}{-@ao;UBZ^5sZbe5MS3b z7M}Ru$`L{kjJ~oq>*TZ@ustWIVbd~uvqt6QgzvY}+6}S~cXF!#OioTRQ1LbyTDJyp z*oZBg%Fm!qPLj9ZhOB0qvhGV+RO7~?A3$!lVrk0936WD1OY%dZec|Wt^Pnt#t~_uM z14C}*TJ#u>(2w47cfWpkdHah|Db@js>7P`;7PipQgIw{_GTyLHjnTyxOO!a>u9m zG{u&!l7cF}4-RuYiq{g{>QJ91$u+>INfH<}DKfz3Up2ty{~X{dn?L?jv1Ruk(iT2V zl0tJ?pQe7*4z&3Pwas5{OU>H+t3v)w%BN{JbG*-|=|9qhG~m_*`)DHl5Hv9cLhxwf zvR`It!d%=XPE8V%S}e+Jt?H&Ir>6R>Qen#$g1tWqBXO_F&*`K==c!Eu`lR2(f+X^+=LDi%3 z(8t>9on?pcHBz!nZKLP*wSYo`ucpyiT-k_C{@&C>UQ2K>;yJ*@dW}Ut6i}{MmStf$ zq0d|@9x7*hj!F&7GJZ;md41RHBh*VDfKadhMV3$>TPB1WT`Fwha~aO{4z#Mq{dIZh z<6NKGndIjc&w7z_XmlI%rII!dV^|ICnqM&)W-jYvRS6}!rt+(~-qKQpT}!axpXR^o!BnH6rAGP6BRuDE0Rd-@!dG*?k=4PaKY z1~99y0oFnU$rPl`w0|ZfI9~oD8o@DPFZk`zJ*|Vel1~y8pbs!T&NY z7w(OWxW}a)|EV5)k3~sn1vXMawtqi9S9vEjX1tSvM%(S$J4w|3RUU^jTDKy%5A;s@ znwk#Jh&(Tx;|Y1_V^yC@LBgbtRa4=(L#BcVZpp7wosettN*;tm#jafncK)8482hPl@vc>@~}DzSLa~lQg_Cyh?3X?vo1-dKYf@_lE?8{m3T6M>FJ~_ z-`k*lcP`Ix*Kvn%*Bm9Vq|P}6NF}ZSkE%Zl>OX-oH5wU;6EW%jK1nDE>NzsBFmR|( zQk!hk2lGmj6F5O6=6+5|GJE>7@EYf;9P9Zk-biDxz8O!f5q~7*jP(8>&PXV8x+Ks`g;l;fT=Oi>NY7e+{3~!q zO3RF?OmhG&ScM(|f26LI38lXRLXuSwwBG5O&?gvyi_gwH=9Nt7YG z7pe%6Ra8faiFrOQg%V|s`=g*teQwopl%fZnXZJi-8x&&R?@DygG0f$v@S{43pzysUwy%t$eA1p89h#!*q2@`+Q+QN5PZcc@ z2RaG*w$9xyXHKUS{c0$EdmcP=`G!;1p4jxFLY&M}H}fsw7W^tFGSYoaeO9o)Dn)W4 zM~gjM>^ZSHg+A;C-EvI_u~PQL<`f;2I)=zouY9GzuRD-Eq7r4yy^2$>9NxtDYrVT* zqF`Z5?cz;t4^2}|OD&FX8ZjPD5U%x|mRY!u%fda*9X}9meWdx;evt2Dpft}-z0wcz z$$gOH)bZIM|2d~qGmx(W7eH=2xyk)dL2k6(!UAkO*&lepxsI*LxoYoXPHenHl)rK- zsGnX`Kc{!%BSt9~x)*G~w6b-?TAk+dA!H)ODW;^b!)$!OiLJZC(g#0!h?;@sPr6T$r> zb){_<{Yruj+Gd_rofE0I!zJ!BQDJ06IU!I;jXrWMHi|0j+vvHAw>_lh`Ed#a=0v*q zX`O=FmY!SHWCfhm5cK@ah-|!*L*~TDzxB=KT;h2Chq?UL53@6(|6DGIeE+9&`Fo6T zW=8xs-fZ4n4&b))8RzoM7cy{F#@o#nrn&!s0$w`xVQNdtT92cRTAR%g_;o%#BLO+}m<$4&L4^%R`>! z-+|}ht1$9Uh@P7{o1cY)m<|=;Is1ZeC;NlmMEakE94KhnFF{6)w(rY4L@knskLtZ~ zUifWq;g{9ga!y^ohlPBlhn*2b_eIhdw1^{MpuFg$$k7?3tV?$YPM!xRxJj?QeG||U zOrzR*P+z#t$Fn}xd^#lB9Cu$zxL6`l!+cK*8-?ZLJsX> z1yTIbf|d$&8Cl}A2l`}*Y@ah{{=q#`1d;c4Fa%GXejxpf9)Jmh55T|G04&+syfv45 zP%&P4gP^YNxFVv1Z^5GD&V2M>x@NUAE9cfB!p|_aBH@#nVi-FznE(#Wg^vyn`x>0U+kWQUS%Xbb%gEUzkPLkgFCATZGikSj?0p`cB)@8qR^V}XXj4 zHkqp)d3cth*xinD7wA0hy?w>D5%h-9k&a>?lj|?w+*ynJr}b5W+hqEBq*wXr*~*i| z5%Z=h2q1u!8Zw39;c|LUdx*)A=fQgymK~ zPG*_A&k-V2BTz(%wX(GQ( zNC*5XKG#21uwro|+y@t{_@cv%C-dA#83*IZeRjV4BB_VS^7gZk?I*+t{xRLv%lL-F zV*Pse^AgkdR4SF&zBkJ+ck$9>axzVBP?EC_K1-}wZaa)mafv@$qOPtY2(3#1+EPfm zkpQ$3s&tks%03z-P?9PukhwpYCU}bAzJ|!CVm->S z+~PWRPV)!?wy@OmtsyQhs}d7PFQqhabYBD4W*SJoBa?|u_by^4sW7W@8aa$#H^?Y; z&8-r*lQVx-Y^AU_Lj1_mWxpue1-Xrns9*P!Y(68Nw-y=}lLNJw$s>xECxk*?Zpz6PzqFP%BK5MnsgP6uIse8yXWBkMj z`f ziwQb2*n;{)cqF5{O~ncnK`A=UJ-4swMVYEo*9+~uVYM*XsaI}qRvMa%vI9K(Z!*9L z9`$y!3=y&atn`{XKngKS2Ee%SW z60f-e&ADkOm0CrGbt(&1-84z=qdmXSy_aqT+nXlUb0r}Em+*gSaukpSt4@o~tgpVQ zBpT|MeYTfftQtP|yS!O!j>D`6qV|!S4-1SXofv19B-*D>vf>w)@Z8oxX4DvkMBpPR zfn2>SCquyjapgD#Xg^1E!V&JCi{TpTp6#*e;$g_xaP{jzt-FOk#3j28{X>aW^TB*G zSk)g+3Xg_S=m@8ROkD!1ajk>$VoP5F#&I9YaT(Mhaah-YvEA zrveK#w7}`Q(ppf&5h{s0$4s5AeYB3v2MOEAQp?%Tg}z7yuICf2In*Q0OKJmGJPLZ3 z?VM;)*vd6u(_M8?w87k4L^Q=6kpg$g-3Qb0l4OM5KzXy1h%@Q_@J9IV!Mh6H&mu~{ z{#Wpx%vR~s;JuQg?t{WRIs@+;Anj0i)%qyx+!@7SB+J`%?KD-Z5P*unt-XKxe#{}&{VP?p0!{rb~mG=%NQCRUJzmt-)@?`e^ z&&$0G?*BLCT$BR;n{qcwd&Gs5Ny1qTVbYLAsqhKK85%FhNHuZ?#>?UOWrgAR4JBbX zCU>H#yM8L_=e#dBVZLa#k2ggicSe2#s||<9!fddaut>6&z54ChMn6%@am{m` z773BKGW`rg))_fQUMbueDV3*>c#0mgW@t{TB!6Eju_DJ$gHT$fwqp@hf1i8-~rh)gv6EM zOL8N1+ak&!t~b8-)HA+l5crd_bq|U4Ldrh#F9w8J{cWY|CVG#>oefF;SJ>LKaWd@0pxFNZNR6Vsj}~{g+o&fjhS81&7_@jl%3BXd`5;xyroKyGED8RvE?4tTqI8E&t%PSz9E5 zNb_q8Id7zO9zw~a6N;{u;J_CJgw3Ukhqel}KWk~(7=094!Pop;+ps$)a-^JeI@!I9 z+i1OoVOgu*T}?83I~1YZpD_1!$YIRZZtldQa~&9a_^CyN=ck#f+4d-zY&nGGo7f$> z7FvZOBA4wT&z^S@rpglXaITs~#UeS#|g%T&KsmZ_-Pz!=IP-rw8mcsZZ}R7ih-b zEu<&>nJj-!lRqcKKCX?7alg}7=Sz38ML(f(FGvQ`T4TwY)VQYwXQ@IRs&Dwy43enj z_QvKE`Ql9lT~i91NvUm3-|TPBFMQg^Tie0t1keG?!feJ$Im>;kT-iQvuSO(|kgs`# z40hZ8$XGkKll4XXyVtaKEF4C4(f~NDjf~>*?V=<36DW*LF9;Yb-!5qK51(Gh!^oyw z`8b|@r4g<-yrJl*R6Z|-5tWXCPt6Rq-b++o1Tnb{gmry@*0YB0X7&cj!pPJZe@>A< zXUdu_HWIaLB&<@|ky%b{NznGWFDbq$Oo6pC6rWPk5T9OpF*#}(vPp8G z4SIwrrKD~P+Ie^@gN+I|z;$d$vlXl`q4mgI>~)llDVh4W)|+JZ zg`m}3xP*(CKvfVg0j=F(tj0^ZD*1lDwbq{5nIvkzbDsbCp65H0?EUU{UElSt`@7z? z7Up(4+&|IuhMkA?j^yg+n4y=_fV+jcaOj%9}P3k#op(4FJ+VMcbBoH z*55`t{0CR9{E5b;yQ~rV`zS4$wNHpM;IYTTk70>?|~)^VDS?Qsm|Kdf<){8LyAA7tet;*V|--&OG5w1q_r*FNv zv$Liz#}32vYfWx$#`jJw5rhQZ@@Kt~S)28bOurAy-P=6=*_$yIY0&#-G<;ThqK_2gTzqSLOk z6)`XSW%#3ain(HE!V}98f3yDG%CnvA?U)>8_}}bIIB_S%b-o*Mzm~A}AJpH615f@r z2<}%RxZP}xLgMDPC~iJ0Jl_H@&>LKX1<_7D;chZ89;t4}WUbS+&bJwB*f?T&)jmg{ zAI5pUXnb1y)(rpKdgd&YG(qxsNiwW(VvSH1aIN)iCfS_oy4HG|)8Vjtq8zZf8eEI? z4#$OR8&N=N+;8zP zK@LRuV=@YpD!j!bXRj1>LA8Q(D;E~ z2c-nYxlWGR?1enF>!&OYMA~^s1+EtTq68Q0qs`?0T z*7VwF#Nokd_{~fEd+Iy^mH~t zEh0sT%>RjVL`{ZqG*r^ae^Bxgx%OP>75knQ{s&B3>l%nTvLjna%rV5)?WFA@*7*fs zi5%O={KT$nH0S7uNZc4E2e17YcmESfFvK8NEu;P^Mm=B|HloSl1=EFlaSnU`Mz2WA zz`%#3MSRtJRI1P+o)T0IG0`s*^?ATeES~NYq>=3Z(|~vzVVZv9MrS0Af07L}S)<(hfOZ<FXy@lsC;}77y$`*gDCR&*j06;FLp;p z9XMJ&E86ZGfg5S31sstkV2J4)|8Q4|G?3xVpy}j)`Ifv>*KDS`&D2FRJr|)b!Z2)jM2NX zlN39;nlRRZ&c(zA>-}%R-2cFRIfC|moktMzsR#xi(f+asy7E*c(a84SDm02{R68|1 z=s22abUS4aLub%pLu52+7O#FhX<#c4=Hi9UT%+t|_fq8(Wo(v@|DmUM>b zfAj|DuqP_0xE07nyWS$*2@$}OE)>k5r zyDY<^eV=ozikjs=P<152GrAQHdR&0QHIJ0!VM<1ABOKZV)k8;U1Yh-8F8kDM^r;Sv zcRik(mDy-6iy&T5eXA#bel9NI^3=@6AYaEV#cK{LZJu5F#4B+Kh@s5`#r|bHKdGpu-=o_+wYgX^q-K|GJH&pS>6{5# zt0`$E@eZ&7y-I;lSi-Sm1y~?*`rpp>@ER(en_lpTVx-VKZWvA9YHipyK8P!3dWoQydKZ z+!X$E`V|N#umK&hsSn1mp&TL!48AZ5<9YxpX10FaW*lNvom>xA33(bv6PXaYS0_`P z3aK#+AZwxe8b{l}(x|((k?u(WzBfp7yS@}dcGTEK8m=5hUC&la#=Lv09K&=aF8J8c zWzoNYzQ)*H*o*jRgAlPmMgt)~2xvMy_ zL%B5PESTyMOa=FQ)o`ey!eG_pzrKS=t$w>fqP60c`oFjqXZ1e=Smn#?Rv?B z{XWd!GkG&BN;j0a-qeSJKrmt=77keOSeVi?p&YpaBkwH{;0F1U!lQunkJ1!dt_?L~2Mc?bW#jsnVBuWOrLhDh18 zxr|DgsyZ`n(f@%=m8B7zo8-a05UQO6wY-{@BQU+Ch;0;}%dzYQ@DtbCl~Vx!f#(Z6 z5OuAjIcB3Pt@Z&p4WE{3JtI+LZ&-P zw*aLig$x$e2Gyk!ee+#us5b0tAk)RzO0F`Ob6kZn)qIStd^s3b-J<_<^ zOkSCoF2*uxIG+f&9iY$S$~+I3Mq+ttMs^zec#I^_cpmnmLpOEw8-IGXbJfa3aUZ2y zGum$U@OBDauD)9I@ED(hpMLPu4}R7biUn6*ONleS&F5FQ2rk9^`p;_Sulj8q>Bv?V zH;}7qK#zE8uEA2Ob|BikM1frh&gGldGTr9`cfiG}A00mop z^nVqDXIEcit)@1X$3LKUDn_(I>l6c#1N!eim!+G#pwV}JhCn+LTJyPFbEk|DIn8EU zMwNksF<-^RFH?>hx57Ek4TNV+zYB4yA=yYAb}Y_)3;9|DUmy^x8ECyf0%d_H=xLMI znV=9_*WOn#!qz4p@bO@MOj7)Bvnp&wO%joLZ$v~OI3X0v8*cWv%HhLs82AmQtCv`} z{&P6{9SnJE(ZgcM%z%C-s-!noY$)r~ZbO$x6(#=za_EKI^B=lOl>u<9Ev5&=W5%j?)At8ZmDjh>t?|>bVshPF6M2MX@=e{gX~mm-4Rh{@ z)b#j;N_te2sLw70=b8fN@93jB*WtgPb1i1DyPRt+n8#*KY^Z3L6IqP$N;vG}el{qa zQ3Y8ZMI2n)wy}FoH1to9SQb8!4oG#NC4nXf*CpbJ(c0@$PaG<$iLA}}TPDzFn z=6>)Qfra%*Knnz>kxUmZjpVEmsVU*8L|zXsHXrmpHbCBV%^0gWV{ok@at4W(nFGNq za>sMxUrY7JU=0xob*xH<4n#)>Bn3#f=5rp>3s}>0=UxAc~;Oiv1#d+wQ$HIhUvF`Hnro0j$#^*2v9NY zL8cfn4el`}a4;0p6LfwN2>ZU6{w($IWn552mTAf}#q@k0x%Rzjy7GHs$}rM29PMZ@ zO~IH>ARR`Urt}z7mozogc`s=S#&i#3GVW4lg?kSNM)ZgDWX-PSk(;o0uX!!Hp$xR5 z`dY5;7^&mf4`W2^^Q$@)a!$AU`|POH_|V9g?+f?a9~tgv-xF@1?&MC!a$b;J6Rpar zAay=cFGvlivxo5h@*~3Y{Ttyu$@3izcJ@NwU&$J>@<-5@@FVDhM!7jWhXkP|;sv5D6f#%TzVd2GH6!p#qeZ+}_csWOlz0kqAH?>h9 z1sJB^yC67=-ZLL#AF`?nswr3p!9>9yzx6E)>|o&O9Qh&^@mMcR>yhf#Z6CH-K>nAD z(aQ)7IDLKfsr&{>XWEve>KBMO;?VpUT{-&h1x@<+R58B&hy$oWm11axb*}j95GCY2 zn3s>;-lzBHottp0$Sd`AP=(V*H~Zf{aMZc(;OMuVNv(lP-0P;|(E7p7b+`7x+Tqzrk=FaE zt?8KXf%V=$(C>tU)~aXlVSOc#G4XSk|IIAx)O~>qBzcIXe$p!I8frHA8=+C&(ALM_ z8ry=|OUCG(85nE4n>q2#%JUh$^U^~YgiMXLzS2b4$5}JDou{#x?-Rd<3SR@Y%JKAI z4ATLVaa^een1W+awTZK;6Dx+0DUmfpahrS1U>rB-N!lJ5gin1m%F<5lQV=9cln}FH zc=|rB%Hp7B8H$wH_k!Um=M?Qp;JndJ+nv^}9fSRi&Ls4Aki8#zzU|wNZ@nYgt;dS9 zKvrLfE;dTvF)!3%47gQv=;vXxF^)mttf!xTi*Oc*(Qm{DiXKWGG^RwIv-8fQ-O$89 zFiishrsAMh=^$wD@27tYD`*|+lPLTVLTCzx()2Ch7$&v}5GbWx9p#G$9C!89XtBd3 zc)|xFlVJ(DEFuJ)Bt)9&`cfG{vQW-unCVq`puP~LuaH*#^wD-w4K+@bGQ>{eF@P6` zxnkZt3+LI^!6|?Dppbi#8jM3_9aC}tILc@}MA8-K7^WSN6E-Zl8#T54)F=c<^$Pqt zrogyzG^^O{9H-!J7ij^-Rm?0c;s{wwU>ab|_P=8Ufzxao>&C(jPs+WtSyFePjk`lm zw0M#lO}-GGFCL2sUWAepb3c4DvrRwr3pqvBdmwGBn*8D(q!U#IGpHhK3eI>=X~Tlp zfpJA1>)rK5)-%H&f`6FmMb=rVGsXAisnY?i)oY}mmana!eqCgp^Uosd<=d_IT`o)y zCoF}VudMS%c1k~2-H-J{+WGF_$(YtdTzY zxc4KO<}p~DOK1{d1>#?&pW66wCqxvxzj9jV#$mlS1*>-{4X`)^pWxi^C<){D!2MU& zx$oiGjR&ijDQ)1*@B_j;C;r#c9%jN#Gwq&}c69$f@I44Gb+B|7zvmMX-sebPJ0iDH zAu{2y&qbs|8sT!}A?e~%_}qr)Z9Isz3@k^H%4x#oBBuLA;31(|c$gQ{B4ADnNCX+T zA$r@$y&_s$>L-9O?*K_(BEVhvZpAmBqj-+NY~*@LcIrk+s$sWZxq};9!WbFH-$6bI zv|SYk9AP2z4-c3A=QSa$Hke_NH)XF19|@bg56_3NW1<@Hz&?~HE6>;WjIG~(q_Sn)wj-zR z#@CtQFTm~g)1Q95{nX*qGJc=BJar+Uwb~g8to4h3!UScTht9!G!msJ(%)F6FNEvLd zdI1op)JWU-S`otG;XfxlQu%en_9K7W#kiWcA38kpBk5=4FX-pqKdI8ay*-fdce?*F z5dQ%n3h~X~0R4L2?rjZ~DBUm^39fDbdTzt^Gq&NEFqAX4)Gy(7+tDwdA8vsGKT@B9 z2^iKUOph|iGjoBo)-`WCdZcbI0*H?jrnXd<@Vx7VP#NBjy9(fWNaOZE&fD9L?y8Hi z3AZ_o+fN1ac|9UdNEGJtV(f&0oR;lpZrcs>k#@#5Z2RGyzi&T0?^7^&cpnkMye62n!CidO5%@VgcVsEy z$8%!@{_))5Gl-wb*@g$K$!RiCO0M2R>%hE(rG%}O`^Rl>Kb-Jh8<0~ejoVvKr=F$7 zX%t2WdP7k@e3v05@i)T_%Hu= zjUOzZqwpb`I>a%Sz8-_G04{KGm}ATeEHH9!(4*ZKLE@CuXx-eh zg{poGp>CCiy82=(24>B`5e}GOeG%?J82VN4x=zc*UW*2A@?_1@ zzeUp)4dmdBxW)a2!W4T_F2*(pn0XTc;R0To=>?&|F~Yzb0m>^6|GV?5xA0<+S0eAD zd&>J5k)KgGK!sV4`#geqpR`-viDtkevK$;T@K|MUz#_5|_WiI_K}H&|NPQT%&>L=O z8;WLMt8X}xNUn3deI!xF=Wkejq_cAhaxW52>aDRTp+gZ~Lwh2eNjKI%LZ1@@MoV2i z_FfewF}|P~G-^dY3O5+yfvVL%2BB`EVqkIB@f@GP1w~aS9Rfr74cLlsj~<5GbwYo_>Ox^{G>Xy~ zS(Jv$qBH<%W}?ivtnNnas2Ala5DSRX!y6JCokC0ut@?&z76gN;=S(`_OloR4%KU_6 zE4HPfJ=U3ov+`N#qIS`a6&x(M6w5+^o!xWaZ*{B};B$Qu6Yk&L+75Q_L5m<-4K@ToUaV)G z-;86gpnQnBZ`~|ZvMi{@!Wo-|J+fI4$64U^KEsL)gRWUK9?CT?Pps5Huiueugqty_KIVfb!Ru`^DWfmnhqoqLx zdCvocBX2zNCJI-oZehMOZE+y2c=MZ0E~*{0>}Ab6nn;40_F}^s@=De#nSHoYi*<*) zJS@l)@F1ztS$n-I`6Aw6$rq%FlHZ6@Ym|JHx&{=DT;wUXtX(3@{&}+O$K#$8Q9P{f z-2q!2%SfP~*xiNOICry0fG?2Ba*wKya*vxK8fCdBKVgPGrco7kU?}XsB9$HLM57ZO zO;o)*36%twNW``}(a$xa9w7BcRO;F8#IpNDKa2*Wp-r?yvJFA9+0vj=Aak(=qxBdf zt2!D18dQe~LlGlgL<2$Qq7$KMyKHV_TTv|$CSqV+lglb%{fJ#3`b#u!tZ&ZMZEWLk zeMM~j8_Y<-U09>$IbRi(?k!fjJ+jiFLhM7Ot7GP(($zV@E7l%nFiM)Lb>JYF559_O z*W^719QVee-X+LtH&E8P{-V-BC3N#XY`%=}_T9?TPy8K()v9ld@I@oS4}qWt9018M zfh}%#tuKmw7vl!yg3jS$KX`$&GW&`O#$a|7f&VQ12%R236pE8Yu|g5sRuqeShOnRp zpRGZ@qtdND5^AfPvH!qmkFoY#$Fk9IED>c``e2!B)lrYom$Mz@00t+d$>9hMfzv#y z;Ybu}e8>RRFA@g0sR(A)S0E=r1KI$SsCtfE&XXn=hfi=czjN-O@gt32R_(h(qEn zSSW|z6t$%p4X_Kb+PSRi=uG&XM>@4b5Z9dPpKf#U3{U@HPfg5I2(dF^wTMsXPhznh zVj-c6<;RJW5x5Jm#%am$${B1OLNsujRM3zzWBiiGc2X`*NK33 z!592=T7TXoq~8v1(gQsy;Nc&Ho#dfY5}OjP2Shz6ho>s{AQq)hX8D`_U!j~pDGK@v z2;mNd(3z0sLLOnM-1pPYgm!#0j~2i-%M|_*m|F1`4ZiuvZ_qAIiNFb1 zi=ZmN?NZ`ouIT#Xt`?l}hU}dQXM=PKU!frqr?-0`+`};hSWClprA`DUBR96H2>mgz zwZ@Z}S?fu}7E7Fq@2SnULtDe5^OOk?2=zU*VJPAanJ7t3J)HRj+PQ3O6Z=fD3BZ4l zV(%|;UptO=)ffE*>VUZ3vX8(c^&H@y(FZ*>)8Oki5DgBYVAR~5$mSs(F&cY6aieBE z4i#;`7(R^rkHFOVr!PUcosYb2p@QQ%*guc-o8Q3&vt^PaQisD_()0%|BsP(}I@acSwEwB^kJwUx; z+20or%6!`A{CV#wuxQ~ycFci7d^5$F%ytDU_+s_H;Y)6y(|6(14}E|=`nw1}Fb6Rs+>gHat}}3Kc?P&I zLeii8GYbMX>0S=o4^WCwzB?0!IEDJ&MS4{zz#M!+^`kT47qEmJc9Dnx0r7~vH}&}p zi0k!erNn_Z-Ind0^KhZttYjP8{n;};{?FJ7W#%_v#qq3fkbcsQRM<6fRG3iU#Myve z*Tk5dmm_cxVg^r9i_hF7P9IT4gS-1!Hjd*+(g?2y>le$1=zo&I=(_;LYH7gfsdXp1 zYTRj_8h0Bu!$G0lZ3liZv)0`PGaV{f2ch_sqTh)1F&um!J_G)g=H)NoO&pOONc6{i3Z1K(NOi2tp_=%2 zfD5TQtDzW6;FK^59?7NIbJS^Jf=}7FizW-|S$>=~_&x>wHp-5v3Hy7H09A?$>U=n5Eh`O5VQE>YthKXIV&2ky`OM3M z?byJEwI!75Pf$2BuilUj+;=$^gRIpT(#oHeZha*>wy37BD?K?@UQGtg7EjgA$c%{} zR(#xkhW`9+RQx^i949F1h>=q5%>Mf5{)i>NnJVPmiPM>I%@j7(clz?_#qGxi(GIBc zd&f9C-*Tm2?6u?QF;J-M<8#GYm<7jS(R>^ru0r-56fybTx^r}g*z1aO6UB&A#E2B@ zb^TO~zJdDlV2@mZ0ry4)W}(9m+(0^wbXuYAmyXmRX^FlQfw2r7!3tt=IpP}aBW zg~2f6_1VEN1Gp}IF0}RvPf{Byt1WmGR}RXLDt zu9&}t&Wsa90G$U)!D(zz7X@LzFOvl!6S?G#MnWz^=6ItrQ5^h_Ca(pNTsyJrLu$T- zCT4Z=Dv~{MN2c|<9qL50C8PAGt~F{(F*S!@)*mzspr-K-WNq!j8v=rs;kzs!H;RQ_ zv^|52ct`1T;mMyEaB~wIh`Gu$amSKNJyoxXI6J-PkjwfwhI|o-K*%c)GB-x-cr_aa zur9dnte`%lrjIMVAUR#Cq=!y1!^tMHi_2vLQ;zoAI2vwm)#T+^=G1)s&_-wvMPQ(d z!AJY=P@P5Jf$!)$S6~$>mBctO zgb1EGt2S}?-v)i)^FC2%_1Fi&q;p0e6bj1zriPOvs@l$0)kk5kgbTZjyPiJ_u5jTn zTb(mDdnOiwjnijWe)j;+-+mQ zJ{y}z;4b|Dd4{n^zbf3f{J>$%K|J|?*~BCsryCqR_@@4%aMJ-dICk=Z&2Z!L|Ah-? z<~=#!fdy^InrC4?@k48M4V>}X;)nb&s5%pIj|bJ7JLtkHjc&QS*f*WDb;?6~AJNv4QFtbrrcuWThPH^YY zPHu#u?!UE~*JO0rIfR*)nriRUw@0(Fly^so3c%B3#b7qezde|ar{GHIdvY0%^*joC z(AR_dR<-r%hxK|dGZGD zDJzU=*OPHf^KAA*7U5s`)ZgXdZXI%8)nRXfNx8S5zULa$C$ZzIlWM;=g!b|L2{t%A z$8>CqKP!a_zn*xk$=4R98{2rqb@E->X=7_fmwh@8{i!OkPlt7it+3iI!F@U#U?lhH zq=~H+)ya?35oQWMaAVIPUyFaeF=U?+mjIUG;3vgeAkRB&)Qr7BU7QyjHP z`2c1`&Z=e$BqmrdfJ_M^=Bi!MBZb5dLJF&^8G=6)9Di%oZU|#79Gf;+U9JAzRl6ca z%CRbNNbRj#j}4}LR9G7_Pn<(!r!ZW~eJJ>|t=>&xQ@{dg0W{bl9$0EecC1TaOL%Q((g>qrdfd!xY>&0FjoE%S4kROETo5 zje?x2-O&(T5y3%JOk-p++KNV|5sE@k^p1ccFOzq?G140YU5WO=Al=Yw(4X(m36%aC z0Af4dG{rj|d#9SPgONg@XvMZwM<5 zU*J}3G6a({x8Ni$8KMB0S77@{-kK|Ih0F+oB0FT)Qc}c>8U(iIBBS~vpaFvU@ob@^ zTo6m4f#My$!{kS#H`WDt!WJ6=DU%Bho$N0EQU4+5>Q6>QS)%mkP}X_$rM;cbn*geS+ z%H~k)hoUT5T{!W(ek3cmH)-My?|DwVY~Zp(98l&P?2P@0g()BkQy`u;LiVXeIai+) z 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 z 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/pythonw.exe b/Rahul/task4/pyvenv3.9/Scripts/pythonw.exe new file mode 100644 index 0000000000000000000000000000000000000000..5ffbf4dbc0de6fef7706f73f84e6702c5e62a547 GIT binary patch literal 542440 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%0A}g<87xGoc*e7)^}^Kj~MW}-S8nb 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 literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/Scripts/tqdm.exe b/Rahul/task4/pyvenv3.9/Scripts/tqdm.exe new file mode 100644 index 0000000000000000000000000000000000000000..4f684537b2efc5d90ae938391ca6aa6b0f356beb GIT binary patch literal 106335 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 be*K#+-{CN#`-Oj)qmm42M_u}u>+XL698vxo literal 0 HcmV?d00001 diff --git a/Rahul/task4/pyvenv3.9/pyvenv.cfg b/Rahul/task4/pyvenv3.9/pyvenv.cfg new file mode 100644 index 00000000..b62cc8f9 --- /dev/null +++ b/Rahul/task4/pyvenv3.9/pyvenv.cfg @@ -0,0 +1,3 @@ +home = C:\Users\Asus\AppData\Local\Programs\Python\Python39 +include-system-site-packages = false +version = 3.9.6 diff --git a/Rahul/task4/query_processing.py b/Rahul/task4/query_processing.py new file mode 100644 index 00000000..65f9bfe1 --- /dev/null +++ b/Rahul/task4/query_processing.py @@ -0,0 +1,35 @@ +import nltk +nltk.download() +from nltk.corpus import stopwords +from nltk.tokenize import word_tokenize +from nltk.stem.porter import PorterStemmer +from spellchecker import SpellChecker +import string +import re + +class QueryProcessing(): + def __init__(self, search_string): + self.search_string = search_string + + def processor(self): + old_query = self.search_string + + self.search_string = self.search_string.lower() + + translator = str.maketrans('', '', string.punctuation) + self.search_string = self.search_string.translate(translator) + + self.search_string = " ".join(self.search_string.split()) + + stop_words = set(stopwords.words("english")) + word_tokens = word_tokenize(self.search_string) + tokens = [word for word in word_tokens if word not in stop_words] + + stemmer = PorterStemmer() + tokens = [stemmer.stem(word) for word in tokens] + + spell = SpellChecker() + for i in range(len(tokens)): + tokens[i] = spell.correction(tokens[i]) + + return tokens \ No newline at end of file diff --git a/Rahul/task4/ranking.py b/Rahul/task4/ranking.py new file mode 100644 index 00000000..de1c6968 --- /dev/null +++ b/Rahul/task4/ranking.py @@ -0,0 +1,57 @@ +from operator import itemgetter +import string + +class Ranking: + def __init__(self, results, query): + self.results = results + self.query = query + + def search(self): + res = [] + filtered = [] + if '"' in self.query: + x = '"' + y = ' ' + z = ' " ' + mytable = self.query.maketrans(x, y, z) + res.insert(0, self.query.translate(mytable)) + else: + if ':' in self.query: + key = self.query.split(':')[0] + fil = self.query.split(':')[1] + print(key) + print(fil) + for result in self.results: + if fil.lower() in result['url'].lower(): + filtered.append(result) + self.results = filtered + elif '-' in self.query: + key = self.query.split('-')[0] + fil = self.query.split('-')[1] + for result in self.results: + if fil.lower() not in result['title'].lower() or fil.lower() not in result['description'].lower(): + filtered.append(result) + self.result = filtered + else: + key = self.query + + res = key.split() + return res + def ranked_results(self): + keywords = self.search() + for key in keywords: + for result in self.results: + if key.lower() in result['title'].lower(): + result['score'] +=2 + if key.lower() in result['description'].lower(): + result['score'] +=1 + + return self.results + + def sorted_results(self): + ranked_searches = self.ranked_results() + + sorted_searches = sorted( + ranked_searches, key=itemgetter('popularity', 'score'), reverse=True) + + return sorted_searches \ No newline at end of file diff --git a/Rahul/task4/static/images/logo.png b/Rahul/task4/static/images/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..60e4b66657f64dcbb9621784372a1dfe1613617d GIT binary patch literal 195981 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%0DTI1_b+T?K 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 IxPkxw1KN+HX#fBK literal 0 HcmV?d00001